+
+
+
\ No newline at end of file
diff --git a/src/src/.idea/jarRepositories.xml b/src/src/.idea/jarRepositories.xml
new file mode 100644
index 0000000..a5f05cd
--- /dev/null
+++ b/src/src/.idea/jarRepositories.xml
@@ -0,0 +1,25 @@
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
\ No newline at end of file
diff --git a/src/src/.idea/libraries/Gradle__androidx_annotation_annotation_1_0_0_jar.xml b/src/src/.idea/libraries/Gradle__androidx_annotation_annotation_1_0_0_jar.xml
new file mode 100644
index 0000000..3740751
--- /dev/null
+++ b/src/src/.idea/libraries/Gradle__androidx_annotation_annotation_1_0_0_jar.xml
@@ -0,0 +1,13 @@
+
+
+
+
+
+
+
+
+
+
+
+
+
\ No newline at end of file
diff --git a/src/src/.idea/libraries/Gradle__androidx_appcompat_appcompat_1_0_0_alpha1_aar.xml b/src/src/.idea/libraries/Gradle__androidx_appcompat_appcompat_1_0_0_alpha1_aar.xml
new file mode 100644
index 0000000..f5e178a
--- /dev/null
+++ b/src/src/.idea/libraries/Gradle__androidx_appcompat_appcompat_1_0_0_alpha1_aar.xml
@@ -0,0 +1,16 @@
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
\ No newline at end of file
diff --git a/src/src/.idea/libraries/Gradle__androidx_arch_core_core_common_2_0_0_jar.xml b/src/src/.idea/libraries/Gradle__androidx_arch_core_core_common_2_0_0_jar.xml
new file mode 100644
index 0000000..83e1a45
--- /dev/null
+++ b/src/src/.idea/libraries/Gradle__androidx_arch_core_core_common_2_0_0_jar.xml
@@ -0,0 +1,11 @@
+
+
+
+
+
+
+
+
+
+
+
\ No newline at end of file
diff --git a/src/src/.idea/libraries/Gradle__androidx_arch_core_core_runtime_2_0_0_aar.xml b/src/src/.idea/libraries/Gradle__androidx_arch_core_core_runtime_2_0_0_aar.xml
new file mode 100644
index 0000000..3fef03d
--- /dev/null
+++ b/src/src/.idea/libraries/Gradle__androidx_arch_core_core_runtime_2_0_0_aar.xml
@@ -0,0 +1,13 @@
+
+
+
+
+
+
+
+
+
+
+
+
+
\ No newline at end of file
diff --git a/src/src/.idea/libraries/Gradle__androidx_asynclayoutinflater_asynclayoutinflater_1_0_0_aar.xml b/src/src/.idea/libraries/Gradle__androidx_asynclayoutinflater_asynclayoutinflater_1_0_0_aar.xml
new file mode 100644
index 0000000..c823c49
--- /dev/null
+++ b/src/src/.idea/libraries/Gradle__androidx_asynclayoutinflater_asynclayoutinflater_1_0_0_aar.xml
@@ -0,0 +1,13 @@
+
+
+
+
+
+
+
+
+
+
+
+
+
\ No newline at end of file
diff --git a/src/src/.idea/libraries/Gradle__androidx_collection_collection_1_0_0_jar.xml b/src/src/.idea/libraries/Gradle__androidx_collection_collection_1_0_0_jar.xml
new file mode 100644
index 0000000..2fee65b
--- /dev/null
+++ b/src/src/.idea/libraries/Gradle__androidx_collection_collection_1_0_0_jar.xml
@@ -0,0 +1,11 @@
+
+
+
+
+
+
+
+
+
+
+
\ No newline at end of file
diff --git a/src/src/.idea/libraries/Gradle__androidx_coordinatorlayout_coordinatorlayout_1_0_0_aar.xml b/src/src/.idea/libraries/Gradle__androidx_coordinatorlayout_coordinatorlayout_1_0_0_aar.xml
new file mode 100644
index 0000000..131db05
--- /dev/null
+++ b/src/src/.idea/libraries/Gradle__androidx_coordinatorlayout_coordinatorlayout_1_0_0_aar.xml
@@ -0,0 +1,16 @@
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
\ No newline at end of file
diff --git a/src/src/.idea/libraries/Gradle__androidx_core_core_1_0_0_aar.xml b/src/src/.idea/libraries/Gradle__androidx_core_core_1_0_0_aar.xml
new file mode 100644
index 0000000..fa1c938
--- /dev/null
+++ b/src/src/.idea/libraries/Gradle__androidx_core_core_1_0_0_aar.xml
@@ -0,0 +1,16 @@
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
\ No newline at end of file
diff --git a/src/src/.idea/libraries/Gradle__androidx_cursoradapter_cursoradapter_1_0_0_aar.xml b/src/src/.idea/libraries/Gradle__androidx_cursoradapter_cursoradapter_1_0_0_aar.xml
new file mode 100644
index 0000000..a1de910
--- /dev/null
+++ b/src/src/.idea/libraries/Gradle__androidx_cursoradapter_cursoradapter_1_0_0_aar.xml
@@ -0,0 +1,13 @@
+
+
+
+
+
+
+
+
+
+
+
+
+
\ No newline at end of file
diff --git a/src/src/.idea/libraries/Gradle__androidx_customview_customview_1_0_0_aar.xml b/src/src/.idea/libraries/Gradle__androidx_customview_customview_1_0_0_aar.xml
new file mode 100644
index 0000000..9924830
--- /dev/null
+++ b/src/src/.idea/libraries/Gradle__androidx_customview_customview_1_0_0_aar.xml
@@ -0,0 +1,13 @@
+
+
+
+
+
+
+
+
+
+
+
+
+
\ No newline at end of file
diff --git a/src/src/.idea/libraries/Gradle__androidx_documentfile_documentfile_1_0_0_aar.xml b/src/src/.idea/libraries/Gradle__androidx_documentfile_documentfile_1_0_0_aar.xml
new file mode 100644
index 0000000..e4cba02
--- /dev/null
+++ b/src/src/.idea/libraries/Gradle__androidx_documentfile_documentfile_1_0_0_aar.xml
@@ -0,0 +1,13 @@
+
+
+
+
+
+
+
+
+
+
+
+
+
\ No newline at end of file
diff --git a/src/src/.idea/libraries/Gradle__androidx_drawerlayout_drawerlayout_1_0_0_aar.xml b/src/src/.idea/libraries/Gradle__androidx_drawerlayout_drawerlayout_1_0_0_aar.xml
new file mode 100644
index 0000000..943f7ca
--- /dev/null
+++ b/src/src/.idea/libraries/Gradle__androidx_drawerlayout_drawerlayout_1_0_0_aar.xml
@@ -0,0 +1,16 @@
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
\ No newline at end of file
diff --git a/src/src/.idea/libraries/Gradle__androidx_fragment_fragment_1_0_0_aar.xml b/src/src/.idea/libraries/Gradle__androidx_fragment_fragment_1_0_0_aar.xml
new file mode 100644
index 0000000..cb9341e
--- /dev/null
+++ b/src/src/.idea/libraries/Gradle__androidx_fragment_fragment_1_0_0_aar.xml
@@ -0,0 +1,16 @@
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
\ No newline at end of file
diff --git a/src/src/.idea/libraries/Gradle__androidx_interpolator_interpolator_1_0_0_aar.xml b/src/src/.idea/libraries/Gradle__androidx_interpolator_interpolator_1_0_0_aar.xml
new file mode 100644
index 0000000..d8a577e
--- /dev/null
+++ b/src/src/.idea/libraries/Gradle__androidx_interpolator_interpolator_1_0_0_aar.xml
@@ -0,0 +1,13 @@
+
+
+
+
+
+
+
+
+
+
+
+
+
\ No newline at end of file
diff --git a/src/src/.idea/libraries/Gradle__androidx_legacy_legacy_support_core_ui_1_0_0_aar.xml b/src/src/.idea/libraries/Gradle__androidx_legacy_legacy_support_core_ui_1_0_0_aar.xml
new file mode 100644
index 0000000..c0535bc
--- /dev/null
+++ b/src/src/.idea/libraries/Gradle__androidx_legacy_legacy_support_core_ui_1_0_0_aar.xml
@@ -0,0 +1,13 @@
+
+
+
+
+
+
+
+
+
+
+
+
+
\ No newline at end of file
diff --git a/src/src/.idea/libraries/Gradle__androidx_legacy_legacy_support_core_utils_1_0_0_aar.xml b/src/src/.idea/libraries/Gradle__androidx_legacy_legacy_support_core_utils_1_0_0_aar.xml
new file mode 100644
index 0000000..229a039
--- /dev/null
+++ b/src/src/.idea/libraries/Gradle__androidx_legacy_legacy_support_core_utils_1_0_0_aar.xml
@@ -0,0 +1,13 @@
+
+
+
+
+
+
+
+
+
+
+
+
+
\ No newline at end of file
diff --git a/src/src/.idea/libraries/Gradle__androidx_legacy_legacy_support_v4_1_0_0_aar.xml b/src/src/.idea/libraries/Gradle__androidx_legacy_legacy_support_v4_1_0_0_aar.xml
new file mode 100644
index 0000000..999fe32
--- /dev/null
+++ b/src/src/.idea/libraries/Gradle__androidx_legacy_legacy_support_v4_1_0_0_aar.xml
@@ -0,0 +1,13 @@
+
+
+
+
+
+
+
+
+
+
+
+
+
\ No newline at end of file
diff --git a/src/src/.idea/libraries/Gradle__androidx_lifecycle_lifecycle_common_2_0_0_jar.xml b/src/src/.idea/libraries/Gradle__androidx_lifecycle_lifecycle_common_2_0_0_jar.xml
new file mode 100644
index 0000000..f2e418b
--- /dev/null
+++ b/src/src/.idea/libraries/Gradle__androidx_lifecycle_lifecycle_common_2_0_0_jar.xml
@@ -0,0 +1,11 @@
+
+
+
+
+
+
+
+
+
+
+
\ No newline at end of file
diff --git a/src/src/.idea/libraries/Gradle__androidx_lifecycle_lifecycle_livedata_2_0_0_aar.xml b/src/src/.idea/libraries/Gradle__androidx_lifecycle_lifecycle_livedata_2_0_0_aar.xml
new file mode 100644
index 0000000..74ad898
--- /dev/null
+++ b/src/src/.idea/libraries/Gradle__androidx_lifecycle_lifecycle_livedata_2_0_0_aar.xml
@@ -0,0 +1,13 @@
+
+
+
+
+
+
+
+
+
+
+
+
+
\ No newline at end of file
diff --git a/src/src/.idea/libraries/Gradle__androidx_lifecycle_lifecycle_livedata_core_2_0_0_aar.xml b/src/src/.idea/libraries/Gradle__androidx_lifecycle_lifecycle_livedata_core_2_0_0_aar.xml
new file mode 100644
index 0000000..fdbb620
--- /dev/null
+++ b/src/src/.idea/libraries/Gradle__androidx_lifecycle_lifecycle_livedata_core_2_0_0_aar.xml
@@ -0,0 +1,13 @@
+
+
+
+
+
+
+
+
+
+
+
+
+
\ No newline at end of file
diff --git a/src/src/.idea/libraries/Gradle__androidx_lifecycle_lifecycle_runtime_2_0_0_aar.xml b/src/src/.idea/libraries/Gradle__androidx_lifecycle_lifecycle_runtime_2_0_0_aar.xml
new file mode 100644
index 0000000..7e84aee
--- /dev/null
+++ b/src/src/.idea/libraries/Gradle__androidx_lifecycle_lifecycle_runtime_2_0_0_aar.xml
@@ -0,0 +1,13 @@
+
+
+
+
+
+
+
+
+
+
+
+
+
\ No newline at end of file
diff --git a/src/src/.idea/libraries/Gradle__androidx_lifecycle_lifecycle_viewmodel_2_0_0_aar.xml b/src/src/.idea/libraries/Gradle__androidx_lifecycle_lifecycle_viewmodel_2_0_0_aar.xml
new file mode 100644
index 0000000..e96be07
--- /dev/null
+++ b/src/src/.idea/libraries/Gradle__androidx_lifecycle_lifecycle_viewmodel_2_0_0_aar.xml
@@ -0,0 +1,13 @@
+
+
+
+
+
+
+
+
+
+
+
+
+
\ No newline at end of file
diff --git a/src/src/.idea/libraries/Gradle__androidx_loader_loader_1_0_0_aar.xml b/src/src/.idea/libraries/Gradle__androidx_loader_loader_1_0_0_aar.xml
new file mode 100644
index 0000000..eff7304
--- /dev/null
+++ b/src/src/.idea/libraries/Gradle__androidx_loader_loader_1_0_0_aar.xml
@@ -0,0 +1,13 @@
+
+
+
+
+
+
+
+
+
+
+
+
+
\ No newline at end of file
diff --git a/src/src/.idea/libraries/Gradle__androidx_localbroadcastmanager_localbroadcastmanager_1_0_0_aar.xml b/src/src/.idea/libraries/Gradle__androidx_localbroadcastmanager_localbroadcastmanager_1_0_0_aar.xml
new file mode 100644
index 0000000..de7a404
--- /dev/null
+++ b/src/src/.idea/libraries/Gradle__androidx_localbroadcastmanager_localbroadcastmanager_1_0_0_aar.xml
@@ -0,0 +1,13 @@
+
+
+
+
+
+
+
+
+
+
+
+
+
\ No newline at end of file
diff --git a/src/src/.idea/libraries/Gradle__androidx_media_media_1_0_0_aar.xml b/src/src/.idea/libraries/Gradle__androidx_media_media_1_0_0_aar.xml
new file mode 100644
index 0000000..a286bab
--- /dev/null
+++ b/src/src/.idea/libraries/Gradle__androidx_media_media_1_0_0_aar.xml
@@ -0,0 +1,16 @@
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
\ No newline at end of file
diff --git a/src/src/.idea/libraries/Gradle__androidx_print_print_1_0_0_aar.xml b/src/src/.idea/libraries/Gradle__androidx_print_print_1_0_0_aar.xml
new file mode 100644
index 0000000..3bd2179
--- /dev/null
+++ b/src/src/.idea/libraries/Gradle__androidx_print_print_1_0_0_aar.xml
@@ -0,0 +1,16 @@
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
\ No newline at end of file
diff --git a/src/src/.idea/libraries/Gradle__androidx_slidingpanelayout_slidingpanelayout_1_0_0_aar.xml b/src/src/.idea/libraries/Gradle__androidx_slidingpanelayout_slidingpanelayout_1_0_0_aar.xml
new file mode 100644
index 0000000..4395962
--- /dev/null
+++ b/src/src/.idea/libraries/Gradle__androidx_slidingpanelayout_slidingpanelayout_1_0_0_aar.xml
@@ -0,0 +1,13 @@
+
+
+
+
+
+
+
+
+
+
+
+
+
\ No newline at end of file
diff --git a/src/src/.idea/libraries/Gradle__androidx_swiperefreshlayout_swiperefreshlayout_1_0_0_aar.xml b/src/src/.idea/libraries/Gradle__androidx_swiperefreshlayout_swiperefreshlayout_1_0_0_aar.xml
new file mode 100644
index 0000000..578ec23
--- /dev/null
+++ b/src/src/.idea/libraries/Gradle__androidx_swiperefreshlayout_swiperefreshlayout_1_0_0_aar.xml
@@ -0,0 +1,16 @@
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
\ No newline at end of file
diff --git a/src/src/.idea/libraries/Gradle__androidx_vectordrawable_vectordrawable_1_0_0_alpha1_aar.xml b/src/src/.idea/libraries/Gradle__androidx_vectordrawable_vectordrawable_1_0_0_alpha1_aar.xml
new file mode 100644
index 0000000..22a582c
--- /dev/null
+++ b/src/src/.idea/libraries/Gradle__androidx_vectordrawable_vectordrawable_1_0_0_alpha1_aar.xml
@@ -0,0 +1,13 @@
+
+
+
+
+
+
+
+
+
+
+
+
+
\ No newline at end of file
diff --git a/src/src/.idea/libraries/Gradle__androidx_vectordrawable_vectordrawable_animated_1_0_0_alpha1_aar.xml b/src/src/.idea/libraries/Gradle__androidx_vectordrawable_vectordrawable_animated_1_0_0_alpha1_aar.xml
new file mode 100644
index 0000000..14bcd4a
--- /dev/null
+++ b/src/src/.idea/libraries/Gradle__androidx_vectordrawable_vectordrawable_animated_1_0_0_alpha1_aar.xml
@@ -0,0 +1,13 @@
+
+
+
+
+
+
+
+
+
+
+
+
+
\ No newline at end of file
diff --git a/src/src/.idea/libraries/Gradle__androidx_versionedparcelable_versionedparcelable_1_0_0_aar.xml b/src/src/.idea/libraries/Gradle__androidx_versionedparcelable_versionedparcelable_1_0_0_aar.xml
new file mode 100644
index 0000000..eafc6e1
--- /dev/null
+++ b/src/src/.idea/libraries/Gradle__androidx_versionedparcelable_versionedparcelable_1_0_0_aar.xml
@@ -0,0 +1,13 @@
+
+
+
+
+
+
+
+
+
+
+
+
+
\ No newline at end of file
diff --git a/src/src/.idea/libraries/Gradle__androidx_viewpager_viewpager_1_0_0_aar.xml b/src/src/.idea/libraries/Gradle__androidx_viewpager_viewpager_1_0_0_aar.xml
new file mode 100644
index 0000000..1054d5e
--- /dev/null
+++ b/src/src/.idea/libraries/Gradle__androidx_viewpager_viewpager_1_0_0_aar.xml
@@ -0,0 +1,13 @@
+
+
+
+
+
+
+
+
+
+
+
+
+
\ No newline at end of file
diff --git a/src/src/.idea/libraries/Gradle__org_apache_http_legacy_android_28.xml b/src/src/.idea/libraries/Gradle__org_apache_http_legacy_android_28.xml
new file mode 100644
index 0000000..d7e2162
--- /dev/null
+++ b/src/src/.idea/libraries/Gradle__org_apache_http_legacy_android_28.xml
@@ -0,0 +1,9 @@
+
+
+
+
+
+
+
+
+
\ No newline at end of file
diff --git a/src/src/.idea/misc.xml b/src/src/.idea/misc.xml
new file mode 100644
index 0000000..6c66119
--- /dev/null
+++ b/src/src/.idea/misc.xml
@@ -0,0 +1,10 @@
+
+
+
+
+
+
+
+
+
+
\ No newline at end of file
diff --git a/src/src/.idea/modules/app/app.iml b/src/src/.idea/modules/app/app.iml
new file mode 100644
index 0000000..474fbc6
--- /dev/null
+++ b/src/src/.idea/modules/app/app.iml
@@ -0,0 +1,28 @@
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ generateDebugSources
+
+
+
+
+
+
+
+
+
+
+
\ No newline at end of file
diff --git a/src/src/.idea/modules/src.iml b/src/src/.idea/modules/src.iml
new file mode 100644
index 0000000..7e68fe2
--- /dev/null
+++ b/src/src/.idea/modules/src.iml
@@ -0,0 +1,15 @@
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
\ No newline at end of file
diff --git a/src/src/.idea/runConfigurations.xml b/src/src/.idea/runConfigurations.xml
new file mode 100644
index 0000000..7f68460
--- /dev/null
+++ b/src/src/.idea/runConfigurations.xml
@@ -0,0 +1,12 @@
+
+
+
+
+
+
+
+
+
+
+
+
\ No newline at end of file
diff --git a/src/src/.idea/sonarIssues.xml b/src/src/.idea/sonarIssues.xml
new file mode 100644
index 0000000..22abbf3
--- /dev/null
+++ b/src/src/.idea/sonarIssues.xml
@@ -0,0 +1,359 @@
+
+
+
+
+
+
+
+
\ No newline at end of file
diff --git a/src/src/.idea/sonarlint-state.xml b/src/src/.idea/sonarlint-state.xml
new file mode 100644
index 0000000..364a433
--- /dev/null
+++ b/src/src/.idea/sonarlint-state.xml
@@ -0,0 +1,6 @@
+
+
+
+ 1602204751633
+
+
\ No newline at end of file
diff --git a/src/src/.idea/sonarlint.xml b/src/src/.idea/sonarlint.xml
new file mode 100644
index 0000000..3f3abcb
--- /dev/null
+++ b/src/src/.idea/sonarlint.xml
@@ -0,0 +1,8 @@
+
+
+
+
+
+
+
+
\ No newline at end of file
diff --git a/src/src/.idea/sonarlint/issuestore/0/2/023468cfdd0b71d4098903b9070e364658e2fbcf b/src/src/.idea/sonarlint/issuestore/0/2/023468cfdd0b71d4098903b9070e364658e2fbcf
new file mode 100644
index 0000000..c2f7ba4
--- /dev/null
+++ b/src/src/.idea/sonarlint/issuestore/0/2/023468cfdd0b71d4098903b9070e364658e2fbcf
@@ -0,0 +1,19 @@
+
+^
+java:S1854I"ARemove this useless assignment to local variable "pendingIntent".(8.
+X java:S125P"").(Қ·8.
+F
+java:S5411"*Use the primitive boolean expression here.(ɯ
+q
+java:S1104?"VMake widgetType a static final constant or non-public and provide accessors if needed.(漬
+w
+java:S2293"YReplace the type specification in this constructor call with the diamond operator ("<>").(Ȫ8.
+l
+java:S11927"ODefine a constant instead of duplicating this literal "Invalid cursor" 3 times.(8ݙ.
+J
+java:S1125s"(Remove the literal "true" boolean value.(ɯ8.
+j
+java:S1104>"TMake widgetId a static final constant or non-public and provide accessors if needed.(ǎ
+>
+java:S1116@"Remove this empty statement.(8.
+v
+java:S2293q"YReplace the type specification in this constructor call with the diamond operator ("<>").(8.
+E
+java:S5411s"*Use the primitive boolean expression here.(ɯ
+I
+java:S1168"+Return an empty collection instead of null.(8.
+r java:S1173"QRename this local variable to match the regular expression '^[a-z][a-zA-Z0-9]*$'.(8ݙ.
+J
+java:S1066i"/Merge this if statement with the enclosing one.(
+
+java:S1319p"mThe return type of this method should be an interface such as "Set" rather than the implementation "HashSet".(ٓ
+m java:S117,"QRename this local variable to match the regular expression '^[a-z][a-zA-Z0-9]*$'.(ķ8ݙ.
+K
+java:S1125"(Remove the literal "true" boolean value.(ɯ8.
+F
+java:S5411"*Use the primitive boolean expression here.(
\ No newline at end of file
diff --git a/src/src/.idea/sonarlint/issuestore/2/b/2b687ab930681e3885683578d43df600a0a20982 b/src/src/.idea/sonarlint/issuestore/2/b/2b687ab930681e3885683578d43df600a0a20982
new file mode 100644
index 0000000..7dba34d
--- /dev/null
+++ b/src/src/.idea/sonarlint/issuestore/2/b/2b687ab930681e3885683578d43df600a0a20982
@@ -0,0 +1,2 @@
+
+b java:S101"MRename this class name to match the regular expression '^[A-Z][a-zA-Z0-9]*$'.(
\ No newline at end of file
diff --git a/src/src/.idea/sonarlint/issuestore/2/b/2bfc771e07e87c37d3a76a2c815bc8fb30649798 b/src/src/.idea/sonarlint/issuestore/2/b/2bfc771e07e87c37d3a76a2c815bc8fb30649798
new file mode 100644
index 0000000..f55555d
--- /dev/null
+++ b/src/src/.idea/sonarlint/issuestore/2/b/2bfc771e07e87c37d3a76a2c815bc8fb30649798
@@ -0,0 +1,12 @@
+
+o
+java:S1128"TRemove this unnecessary import: same package classes are always implicitly imported.(
+Q
+java:S1874P"5Remove this use of "FORMAT_12HOUR"; it is deprecated.(ח$8.
+L
+java:S1874="1Remove this use of "setButton"; it is deprecated.(
+H
+java:S1874>"2Remove this use of "setButton2"; it is deprecated.(
+h java:S100("NRename this method name to match the regular expression '^[a-z][a-zA-Z0-9]*$'.(
+J
+java:S1874P"5Remove this use of "FORMAT_24HOUR"; it is deprecated.(ח$
\ No newline at end of file
diff --git a/src/src/.idea/sonarlint/issuestore/3/2/32360bf24febc78f20db52498c7576b3d8650d56 b/src/src/.idea/sonarlint/issuestore/3/2/32360bf24febc78f20db52498c7576b3d8650d56
new file mode 100644
index 0000000..d8aa9ab
--- /dev/null
+++ b/src/src/.idea/sonarlint/issuestore/3/2/32360bf24febc78f20db52498c7576b3d8650d56
@@ -0,0 +1,35 @@
+
+c
+java:S1192x"HDefine a constant instead of duplicating this literal "=? AND " 4 times.(
+m
+java:S3252"QUse static access with "net.micode.notes.data.Notes$DataColumns" for "MIME_TYPE".(
+
+java:S1319S"kThe type of the "ids" object should be an interface such as "Set" rather than the implementation "HashSet".(
+J
+java:S1066~"/Merge this if statement with the enclosing one.(䲜
+T
+java:S1155-">Use isEmpty() to check whether the collection is empty or not.(
+
+java:S1319("kThe type of the "ids" object should be an interface such as "Set" rather than the implementation "HashSet".(
+U
+java:S1118&":Add a private constructor to hide the implicit public one.(
+u
+java:S2293"YReplace the type specification in this constructor call with the diamond operator ("<>").(ª
+
+java:S1319"mThe return type of this method should be an interface such as "Set" rather than the implementation "HashSet".(
+m
+java:S3252"QUse static access with "net.micode.notes.data.Notes$DataColumns" for "MIME_TYPE".(
+b
+java:S1192D"GDefine a constant instead of duplicating this literal "%s: %s" 4 times.(
+[
+java:S2147l"ECombine this catch with the one at line 106, which has the same body.(暩
+k
+java:S3252"OUse static access with "net.micode.notes.data.Notes$DataColumns" for "NOTE_ID".(
+t
+java:S22932"YReplace the type specification in this constructor call with the diamond operator ("<>").(л
+t
+java:S2293Z"YReplace the type specification in this constructor call with the diamond operator ("<>").(л
+f
+java:S3252"OUse static access with "net.micode.notes.data.Notes$DataColumns" for "NOTE_ID".(ʹ
+Z
+java:S2147E"DCombine this catch with the one at line 67, which has the same body.(暩
\ No newline at end of file
diff --git a/src/src/.idea/sonarlint/issuestore/3/7/378bb2a1bb01310577dee8f681e56a9ee80253c4 b/src/src/.idea/sonarlint/issuestore/3/7/378bb2a1bb01310577dee8f681e56a9ee80253c4
new file mode 100644
index 0000000..a91649e
--- /dev/null
+++ b/src/src/.idea/sonarlint/issuestore/3/7/378bb2a1bb01310577dee8f681e56a9ee80253c4
@@ -0,0 +1,4 @@
+
+q
+java:S1450"VRemove the "gesture" field and declare it as a local variable in the relevant methods.(
+k java:S117D"QRename this local variable to match the regular expression '^[a-z][a-zA-Z0-9]*$'.(
\ No newline at end of file
diff --git a/src/src/.idea/sonarlint/issuestore/3/a/3aac5305cb73bfbdeb8078cd264d04323fa80e92 b/src/src/.idea/sonarlint/issuestore/3/a/3aac5305cb73bfbdeb8078cd264d04323fa80e92
new file mode 100644
index 0000000..e69de29
diff --git a/src/src/.idea/sonarlint/issuestore/3/e/3e688be40dc69cfd1062f41d0fc27fe261a26710 b/src/src/.idea/sonarlint/issuestore/3/e/3e688be40dc69cfd1062f41d0fc27fe261a26710
new file mode 100644
index 0000000..09b34df
--- /dev/null
+++ b/src/src/.idea/sonarlint/issuestore/3/e/3e688be40dc69cfd1062f41d0fc27fe261a26710
@@ -0,0 +1,26 @@
+
+X java:S125L"").(各8.
+Y java:S125"").(
\ No newline at end of file
diff --git a/src/src/.idea/sonarlint/issuestore/5/7/577f30d26378ec8a2bd2e4a43f3c79b3f04c402c b/src/src/.idea/sonarlint/issuestore/5/7/577f30d26378ec8a2bd2e4a43f3c79b3f04c402c
new file mode 100644
index 0000000..e84df14
--- /dev/null
+++ b/src/src/.idea/sonarlint/issuestore/5/7/577f30d26378ec8a2bd2e4a43f3c79b3f04c402c
@@ -0,0 +1,84 @@
+
+s java:S117"QRename this local variable to match the regular expression '^[a-z][a-zA-Z0-9]*$'.(ӏ8.
+|
+java:S2293"YReplace the type specification in this constructor call with the diamond operator ("<>").(8.
+k
+java:S3252"MUse static access with "android.provider.MediaStore$MediaColumns" for "DATA".(8.
+
+java:S1149"_Replace the synchronized class "StringBuffer" by an unsynchronized one such as "StringBuilder".(᯲8.
+r
+java:S1104"OMake mId a static final constant or non-public and provide accessors if needed.(8.
+\
+java:S1874"9Remove this use of "setTextAppearance"; it is deprecated.(8.
+k
+java:S3252 "MUse static access with "android.text.Spanned" for "SPAN_INCLUSIVE_EXCLUSIVE".(8.
+[
+java:S1874"=Remove this use of "EXTRA_SHORTCUT_INTENT"; it is deprecated.(ð8.
+y
+java:S1104p"WMake ivAlertIcon a static final constant or non-public and provide accessors if needed.(න8і.
+k
+java:S3252"MUse static access with "android.text.Spanned" for "SPAN_INCLUSIVE_EXCLUSIVE".(8.
+w
+java:S2293"YReplace the type specification in this constructor call with the diamond operator ("<>").(艥8.
+w
+java:S2293"YReplace the type specification in this constructor call with the diamond operator ("<>").(8.
+V
+java:S1874"9Remove this use of "setTextAppearance"; it is deprecated.((8.
+?
+java:S1116"Remove this empty statement.(8.
+e
+java:S1126"BReplace this if-then-else statement by a single method invocation.(8.
+p
+java:S3252"MUse static access with "android.provider.MediaStore$MediaColumns" for "DATA".(ԡ8.
+z
+java:S1104t"XMake ibSetBgColor a static final constant or non-public and provide accessors if needed.(8і.
+|
+java:S2293"YReplace the type specification in this constructor call with the diamond operator ("<>").(8.
+^ java:S125"").(ӏ8.
\ No newline at end of file
diff --git a/src/src/.idea/sonarlint/issuestore/5/8/58052a8597c5f01595e1c849728bcae66c27a1a6 b/src/src/.idea/sonarlint/issuestore/5/8/58052a8597c5f01595e1c849728bcae66c27a1a6
new file mode 100644
index 0000000..07745a6
--- /dev/null
+++ b/src/src/.idea/sonarlint/issuestore/5/8/58052a8597c5f01595e1c849728bcae66c27a1a6
@@ -0,0 +1,5 @@
+
+3
+java:S2386$"Make this member "protected".(
+h
+java:S3776H"RRefactor this method to reduce its Cognitive Complexity from 19 to the 15 allowed.(ʃ
\ No newline at end of file
diff --git a/src/src/.idea/sonarlint/issuestore/5/8/5836a695995df8fadacfa6409fe8d21d88946842 b/src/src/.idea/sonarlint/issuestore/5/8/5836a695995df8fadacfa6409fe8d21d88946842
new file mode 100644
index 0000000..e69de29
diff --git a/src/src/.idea/sonarlint/issuestore/5/d/5dfe6902d8ec740690f88d644e74362c3be08fad b/src/src/.idea/sonarlint/issuestore/5/d/5dfe6902d8ec740690f88d644e74362c3be08fad
new file mode 100644
index 0000000..9ea8b5f
--- /dev/null
+++ b/src/src/.idea/sonarlint/issuestore/5/d/5dfe6902d8ec740690f88d644e74362c3be08fad
@@ -0,0 +1,9 @@
+
+m
+java:S37765"RRefactor this method to reduce its Cognitive Complexity from 25 to the 15 allowed.(û
+V
+java:S1874Y"9Remove this use of "setTextAppearance"; it is deprecated.(8̠.
+V
+java:S1874A"9Remove this use of "setTextAppearance"; it is deprecated.(8̠.
+V
+java:S1874H"9Remove this use of "setTextAppearance"; it is deprecated.(8̠.
\ No newline at end of file
diff --git a/src/src/.idea/sonarlint/issuestore/5/f/5f6162ca79fcea353b280c5dc84973a9c37d2c74 b/src/src/.idea/sonarlint/issuestore/5/f/5f6162ca79fcea353b280c5dc84973a9c37d2c74
new file mode 100644
index 0000000..e69de29
diff --git a/src/src/.idea/sonarlint/issuestore/6/a/6a65e747031f27aef20597b4181148a9fbf963d5 b/src/src/.idea/sonarlint/issuestore/6/a/6a65e747031f27aef20597b4181148a9fbf963d5
new file mode 100644
index 0000000..5eb21fb
--- /dev/null
+++ b/src/src/.idea/sonarlint/issuestore/6/a/6a65e747031f27aef20597b4181148a9fbf963d5
@@ -0,0 +1,15 @@
+
+M
+java:S1153"1Directly append the argument of String.valueOf().(ߦ
+N
+java:S1135"2Complete the task associated to this TODO comment.(
+
+java:S3008L"eRename this field "NOTES_SNIPPET_SEARCH_QUERY" to match the regular expression '^[a-z][a-zA-Z0-9]*$'.(
+D
+java:S1659"(Declare "insertedId" on a separate line.(ؘ
+T
+java:S2130"8Use "Long.parseLong" for this string-to-long conversion.(
+i
+java:S1192"MDefine a constant instead of duplicating this literal "Unknown URI " 4 times.(
+@
+java:S1659"$Declare "noteId" on a separate line.(ؘ
\ No newline at end of file
diff --git a/src/src/.idea/sonarlint/issuestore/6/c/6cbf8bd9aa98eff862b1dc067330ba66ba4493aa b/src/src/.idea/sonarlint/issuestore/6/c/6cbf8bd9aa98eff862b1dc067330ba66ba4493aa
new file mode 100644
index 0000000..f0ad061
--- /dev/null
+++ b/src/src/.idea/sonarlint/issuestore/6/c/6cbf8bd9aa98eff862b1dc067330ba66ba4493aa
@@ -0,0 +1,3 @@
+
+V
+java:S3398"?Move this method into the anonymous class declared at line 118.(
\ No newline at end of file
diff --git a/src/src/.idea/sonarlint/issuestore/7/e/7e95080e97eb945562bad95d376a9dbe3224954d b/src/src/.idea/sonarlint/issuestore/7/e/7e95080e97eb945562bad95d376a9dbe3224954d
new file mode 100644
index 0000000..54a4739
--- /dev/null
+++ b/src/src/.idea/sonarlint/issuestore/7/e/7e95080e97eb945562bad95d376a9dbe3224954d
@@ -0,0 +1,24 @@
+
+M
+java:S1854!"7Remove this useless assignment to local variable "dim".(
+b
+java:S2259T"@A "NullPointerException" could be thrown; "bm" is nullable here.(Ȳ8ڣ.
+j
+java:S4042"NUse "java.nio.file.Files#delete" here for better messages on error conditions.(
+G
+java:S1874"0Remove this use of "inDither"; it is deprecated.(Ծ
+N
+java:S2589"7Remove this expression which always evaluates to "true"(
+R java:S125"").(艥
+D
+java:S1199"-Extract this nested code block into a method.(
+8
+java:S1116"Remove this empty statement.(
+I
+java:S1199"-Extract this nested code block into a method.(ڿ
+A
+java:S3398"%Move this method into "ModeCallback".(
+I
+java:S1172"-Remove this unused method parameter "unused".(Ԃ
+=
+java:S1172"&Remove these unused method parameters.(
\ No newline at end of file
diff --git a/src/src/.idea/sonarlint/issuestore/9/a/9a3a19793537958b8b1b03a81985999e22705a2f b/src/src/.idea/sonarlint/issuestore/9/a/9a3a19793537958b8b1b03a81985999e22705a2f
new file mode 100644
index 0000000..5db51fa
--- /dev/null
+++ b/src/src/.idea/sonarlint/issuestore/9/a/9a3a19793537958b8b1b03a81985999e22705a2f
@@ -0,0 +1,11 @@
+
+t
+java:S2293)"YReplace the type specification in this constructor call with the diamond operator ("<>").(
+x
+java:S3252!"VUse static access with "android.provider.ContactsContract$DataColumns" for "MIMETYPE".(8Ɂ.
+P
+java:S1118":Add a private constructor to hide the implicit public one.(
+r
+java:S3252""\Use static access with "android.provider.ContactsContract$DataColumns" for "RAW_CONTACT_ID".(
+t
+java:S32524"^Use static access with "android.provider.ContactsContract$ContactsColumns" for "DISPLAY_NAME".(
\ No newline at end of file
diff --git a/src/src/.idea/sonarlint/issuestore/a/4/a446c87b1013132f8adaf83656b582028e8809af b/src/src/.idea/sonarlint/issuestore/a/4/a446c87b1013132f8adaf83656b582028e8809af
new file mode 100644
index 0000000..c01b275
--- /dev/null
+++ b/src/src/.idea/sonarlint/issuestore/a/4/a446c87b1013132f8adaf83656b582028e8809af
@@ -0,0 +1,23 @@
+
+Y java:S125"").(
+c
+java:S2147"ECombine this catch with the one at line 151, which has the same body.(8.
+]
+java:S1192"FDefine a constant instead of duplicating this literal " DESC" 3 times.(Ա
+n
+java:S3776"RRefactor this method to reduce its Cognitive Complexity from 20 to the 15 allowed.(ƶؠ
+Y java:S125"").(
+Y java:S125"").(
+C
+java:S1905"-Remove this unnecessary cast to "JSONObject".(؛
+>
+java:S1905"'Remove this unnecessary cast to "Node".(
+t
+java:S2293_"YReplace the type specification in this constructor call with the diamond operator ("<>").(
+t
+java:S2293c"YReplace the type specification in this constructor call with the diamond operator ("<>").(
+K
+java:S1066"/Merge this if statement with the enclosing one.(
+n
+java:S3776"RRefactor this method to reduce its Cognitive Complexity from 34 to the 15 allowed.(ɸ
+i
+java:S3776"RRefactor this method to reduce its Cognitive Complexity from 29 to the 15 allowed.(þ
+t
+java:S2293^"YReplace the type specification in this constructor call with the diamond operator ("<>").(
+Y java:S125"Remove this use of "setDrawingCacheEnabled"; it is deprecated.(
+M
+java:S1874D"7Remove this use of "getDrawingCache"; it is deprecated.(
+O
+java:S1874T"9Remove this use of "buildDrawingCache"; it is deprecated.(ݛ
+U
+java:S1118":Add a private constructor to hide the implicit public one.(
+M
+java:S1874U"7Remove this use of "getDrawingCache"; it is deprecated.(
+Y
+java:S1874B">Remove this use of "setDrawingCacheEnabled"; it is deprecated.(
+Q
+java:S1874I";Remove this use of "destroyDrawingCache"; it is deprecated.(
+Q
+java:S1874^";Remove this use of "destroyDrawingCache"; it is deprecated.(
+O
+java:S1874C"9Remove this use of "buildDrawingCache"; it is deprecated.(ݛ
\ No newline at end of file
diff --git a/src/src/.idea/sonarlint/issuestore/a/d/ad72331a1bed265bb9c0fe838faa74dbf69fce32 b/src/src/.idea/sonarlint/issuestore/a/d/ad72331a1bed265bb9c0fe838faa74dbf69fce32
new file mode 100644
index 0000000..b032536
--- /dev/null
+++ b/src/src/.idea/sonarlint/issuestore/a/d/ad72331a1bed265bb9c0fe838faa74dbf69fce32
@@ -0,0 +1,94 @@
+
+s java:S117 "QRename this local variable to match the regular expression '^[a-z][a-zA-Z0-9]*$'.(8.
+P
+java:S1199"-Extract this nested code block into a method.(8.
+o java:S101"MRename this class name to match the regular expression '^[A-Z][a-zA-Z0-9]*$'.(8.
+c
+java:S1124"EReorder the modifiers to comply with the Java Language Specification.(Ϋ8.
+u
+java:S3252"RUse static access with "android.widget.AbsListView" for "MultiChoiceModeListener".(8.
+o
+java:S3776 "RRefactor this method to reduce its Cognitive Complexity from 16 to the 15 allowed.(-8.
+H
+java:S3398 "%Move this method into "ModeCallback".(LjԔ8.
+u
+java:S1450"XRemove the "mMoveMenu" field and declare it as a local variable in the relevant methods.(`8.
+w
+java:S2293"YReplace the type specification in this constructor call with the diamond operator ("<>").(艥8.
+P
+java:S1199"-Extract this nested code block into a method.(̀8.
+U
+java:S1135"2Complete the task associated to this TODO comment.(8.
+J
+java:S1199"-Extract this nested code block into a method.(Փ58.
+k java:S100"NRename this method name to match the regular expression '^[a-z][a-zA-Z0-9]*$'.(8.
+U
+java:S1135"2Complete the task associated to this TODO comment.(8.
+H
+java:S3398"%Move this method into "ModeCallback".(핺8.
+O
+java:S1874"1Remove this use of "getHeight"; it is deprecated.(Á8.
+U
+java:S1135"2Complete the task associated to this TODO comment.(8.
+K
+java:S1199"-Extract this nested code block into a method.(ȓ8.
+p
+java:S3776"RRefactor this method to reduce its Cognitive Complexity from 18 to the 15 allowed.(Թ8.
+U
+java:S1135"2Complete the task associated to this TODO comment.(8.
+U
+java:S1135"2Complete the task associated to this TODO comment.(8.
+U
+java:S1135"2Complete the task associated to this TODO comment.(8.
+u
+java:S3776"RRefactor this method to reduce its Cognitive Complexity from 20 to the 15 allowed.(핺8.
+o java:S101"MRename this class name to match the regular expression '^[A-Z][a-zA-Z0-9]*$'.(8.
+h
+java:S1124"EReorder the modifiers to comply with the Java Language Specification.(я8.
+x java:S116"[Rename this field "gestures_overlay" to match the regular expression '^[a-z][a-zA-Z0-9]*$'.(8ܬ.
+U
+java:S1135 "2Complete the task associated to this TODO comment.(8.
+K
+java:S1199"-Extract this nested code block into a method.(8.
+P
+java:S1199"-Extract this nested code block into a method.(8.
+\
+java:S1124"EReorder the modifiers to comply with the Java Language Specification.(۞ƣ
+9
+java:S3626"Remove this redundant jump.(݅8.
+P
+java:S1199"-Extract this nested code block into a method.(8.
+9
+java:S3626"Remove this redundant jump.(݅8.
+U
+java:S1874"7Remove this use of "GestureDetector"; it is deprecated.(8.
+U
+java:S1135"2Complete the task associated to this TODO comment.(8.
+R
+java:S3398"/Move this method into "BackgroundQueryHandler".(8.
+P
+java:S1199"-Extract this nested code block into a method.(ڿ8.
+U
+java:S1135"2Complete the task associated to this TODO comment.(8.
+x java:S116"VRename this field "GestureMode" to match the regular expression '^[a-z][a-zA-Z0-9]*$'.(8.
+K
+java:S1199"-Extract this nested code block into a method.(8.
+U
+java:S1135"2Complete the task associated to this TODO comment.(8.
+U
+java:S1135 "2Complete the task associated to this TODO comment.(8.
+^ java:S125"Remove this unused import 'net.micode.notes.tool.ScreenUtils'.(Ś8.
+Q
+java:S1161":Add the "@Override" annotation above this method signature(
+a
+java:S1128"?Remove this unused import 'android.gesture.GestureOverlayView'.(8.
+g
+java:S1301"KReplace this "switch" statement by "if" statements to increase readability.(崡
+D
+java:S1128*".Remove this unused import 'android.view.Menu'.(҅
+V
+java:S1128"4Remove this unused import 'android.gesture.Gesture'.(8.
+H
+java:S1128"2Remove this unused import 'android.app.ActionBar'.(
+M
+java:S11288"0Remove this unused import 'java.util.ArrayList'.(8.
+V java:S110="").(л
+i
+java:S3776"RRefactor this method to reduce its Cognitive Complexity from 23 to the 15 allowed.(
+U
+java:S1155">Use isEmpty() to check whether the collection is empty or not.(
+j
+java:S1192?"ODefine a constant instead of duplicating this literal "Wrong note id:" 3 times.(
\ No newline at end of file
diff --git a/src/src/.idea/sonarlint/issuestore/e/0/e094aec5c3e1b6f44539adff3114f5a1ad603ddc b/src/src/.idea/sonarlint/issuestore/e/0/e094aec5c3e1b6f44539adff3114f5a1ad603ddc
new file mode 100644
index 0000000..4588801
--- /dev/null
+++ b/src/src/.idea/sonarlint/issuestore/e/0/e094aec5c3e1b6f44539adff3114f5a1ad603ddc
@@ -0,0 +1,11 @@
+
+X java:S125~"").(ʩ
+X java:S125F"").(
+u
+java:S2293"YReplace the type specification in this constructor call with the diamond operator ("<>").(
+u
+java:S2293"YReplace the type specification in this constructor call with the diamond operator ("<>").(
+Y java:S125"
+
+
+
+
+
+
+
+
+
+
\ No newline at end of file
diff --git a/src/src/.idea/vcs.xml b/src/src/.idea/vcs.xml
new file mode 100644
index 0000000..6c0b863
--- /dev/null
+++ b/src/src/.idea/vcs.xml
@@ -0,0 +1,6 @@
+
+
+
+
+
+
\ No newline at end of file
diff --git a/src/src/.project b/src/src/.project
new file mode 100644
index 0000000..f05f5d7
--- /dev/null
+++ b/src/src/.project
@@ -0,0 +1,28 @@
+
+
+ src
+ Project src created by Buildship.
+
+
+
+
+ org.eclipse.buildship.core.gradleprojectbuilder
+
+
+
+
+
+ org.eclipse.buildship.core.gradleprojectnature
+
+
+
+ 1614081047261
+
+ 30
+
+ org.eclipse.core.resources.regexFilterMatcher
+ node_modules|.git|__CREATED_BY_JAVA_LANGUAGE_SERVER__
+
+
+
+
diff --git a/src/src/.settings/org.eclipse.buildship.core.prefs b/src/src/.settings/org.eclipse.buildship.core.prefs
new file mode 100644
index 0000000..27b37ed
--- /dev/null
+++ b/src/src/.settings/org.eclipse.buildship.core.prefs
@@ -0,0 +1,13 @@
+arguments=
+auto.sync=false
+build.scans.enabled=false
+connection.gradle.distribution=GRADLE_DISTRIBUTION(WRAPPER)
+connection.project.dir=
+eclipse.preferences.version=1
+gradle.user.home=
+java.home=C\:/Program Files/Java/jdk-11.0.8
+jvm.arguments=
+offline.mode=false
+override.workspace.settings=true
+show.console.view=true
+show.executions.view=true
diff --git a/src/src/Notes-master/.gitignore b/src/src/Notes-master/.gitignore
new file mode 100644
index 0000000..7df8dff
--- /dev/null
+++ b/src/src/Notes-master/.gitignore
@@ -0,0 +1,9 @@
+# generated files
+bin/
+gen/
+
+# Local configuration file (sdk path, etc)
+project.properties
+.settings/
+.classpath
+.project
diff --git a/src/src/Notes-master/AndroidManifest.xml b/src/src/Notes-master/AndroidManifest.xml
new file mode 100644
index 0000000..e5c7d47
--- /dev/null
+++ b/src/src/Notes-master/AndroidManifest.xml
@@ -0,0 +1,150 @@
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
diff --git a/src/src/Notes-master/NOTICE b/src/src/Notes-master/NOTICE
new file mode 100644
index 0000000..9a54521
--- /dev/null
+++ b/src/src/Notes-master/NOTICE
@@ -0,0 +1,190 @@
+
+ Copyright (c) 2010-2011, The MiCode Open Source Community (www.micode.net)
+
+ Licensed under the Apache License, Version 2.0 (the "License");
+ you may not use this file except in compliance with the License.
+
+ Unless required by applicable law or agreed to in writing, software
+ distributed under the License is distributed on an "AS IS" BASIS,
+ WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ See the License for the specific language governing permissions and
+ limitations under the License.
+
+
+ Apache License
+ Version 2.0, January 2004
+ http://www.apache.org/licenses/
+
+ TERMS AND CONDITIONS FOR USE, REPRODUCTION, AND DISTRIBUTION
+
+ 1. Definitions.
+
+ "License" shall mean the terms and conditions for use, reproduction,
+ and distribution as defined by Sections 1 through 9 of this document.
+
+ "Licensor" shall mean the copyright owner or entity authorized by
+ the copyright owner that is granting the License.
+
+ "Legal Entity" shall mean the union of the acting entity and all
+ other entities that control, are controlled by, or are under common
+ control with that entity. For the purposes of this definition,
+ "control" means (i) the power, direct or indirect, to cause the
+ direction or management of such entity, whether by contract or
+ otherwise, or (ii) ownership of fifty percent (50%) or more of the
+ outstanding shares, or (iii) beneficial ownership of such entity.
+
+ "You" (or "Your") shall mean an individual or Legal Entity
+ exercising permissions granted by this License.
+
+ "Source" form shall mean the preferred form for making modifications,
+ including but not limited to software source code, documentation
+ source, and configuration files.
+
+ "Object" form shall mean any form resulting from mechanical
+ transformation or translation of a Source form, including but
+ not limited to compiled object code, generated documentation,
+ and conversions to other media types.
+
+ "Work" shall mean the work of authorship, whether in Source or
+ Object form, made available under the License, as indicated by a
+ copyright notice that is included in or attached to the work
+ (an example is provided in the Appendix below).
+
+ "Derivative Works" shall mean any work, whether in Source or Object
+ form, that is based on (or derived from) the Work and for which the
+ editorial revisions, annotations, elaborations, or other modifications
+ represent, as a whole, an original work of authorship. For the purposes
+ of this License, Derivative Works shall not include works that remain
+ separable from, or merely link (or bind by name) to the interfaces of,
+ the Work and Derivative Works thereof.
+
+ "Contribution" shall mean any work of authorship, including
+ the original version of the Work and any modifications or additions
+ to that Work or Derivative Works thereof, that is intentionally
+ submitted to Licensor for inclusion in the Work by the copyright owner
+ or by an individual or Legal Entity authorized to submit on behalf of
+ the copyright owner. For the purposes of this definition, "submitted"
+ means any form of electronic, verbal, or written communication sent
+ to the Licensor or its representatives, including but not limited to
+ communication on electronic mailing lists, source code control systems,
+ and issue tracking systems that are managed by, or on behalf of, the
+ Licensor for the purpose of discussing and improving the Work, but
+ excluding communication that is conspicuously marked or otherwise
+ designated in writing by the copyright owner as "Not a Contribution."
+
+ "Contributor" shall mean Licensor and any individual or Legal Entity
+ on behalf of whom a Contribution has been received by Licensor and
+ subsequently incorporated within the Work.
+
+ 2. Grant of Copyright License. Subject to the terms and conditions of
+ this License, each Contributor hereby grants to You a perpetual,
+ worldwide, non-exclusive, no-charge, royalty-free, irrevocable
+ copyright license to reproduce, prepare Derivative Works of,
+ publicly display, publicly perform, sublicense, and distribute the
+ Work and such Derivative Works in Source or Object form.
+
+ 3. Grant of Patent License. Subject to the terms and conditions of
+ this License, each Contributor hereby grants to You a perpetual,
+ worldwide, non-exclusive, no-charge, royalty-free, irrevocable
+ (except as stated in this section) patent license to make, have made,
+ use, offer to sell, sell, import, and otherwise transfer the Work,
+ where such license applies only to those patent claims licensable
+ by such Contributor that are necessarily infringed by their
+ Contribution(s) alone or by combination of their Contribution(s)
+ with the Work to which such Contribution(s) was submitted. If You
+ institute patent litigation against any entity (including a
+ cross-claim or counterclaim in a lawsuit) alleging that the Work
+ or a Contribution incorporated within the Work constitutes direct
+ or contributory patent infringement, then any patent licenses
+ granted to You under this License for that Work shall terminate
+ as of the date such litigation is filed.
+
+ 4. Redistribution. You may reproduce and distribute copies of the
+ Work or Derivative Works thereof in any medium, with or without
+ modifications, and in Source or Object form, provided that You
+ meet the following conditions:
+
+ (a) You must give any other recipients of the Work or
+ Derivative Works a copy of this License; and
+
+ (b) You must cause any modified files to carry prominent notices
+ stating that You changed the files; and
+
+ (c) You must retain, in the Source form of any Derivative Works
+ that You distribute, all copyright, patent, trademark, and
+ attribution notices from the Source form of the Work,
+ excluding those notices that do not pertain to any part of
+ the Derivative Works; and
+
+ (d) If the Work includes a "NOTICE" text file as part of its
+ distribution, then any Derivative Works that You distribute must
+ include a readable copy of the attribution notices contained
+ within such NOTICE file, excluding those notices that do not
+ pertain to any part of the Derivative Works, in at least one
+ of the following places: within a NOTICE text file distributed
+ as part of the Derivative Works; within the Source form or
+ documentation, if provided along with the Derivative Works; or,
+ within a display generated by the Derivative Works, if and
+ wherever such third-party notices normally appear. The contents
+ of the NOTICE file are for informational purposes only and
+ do not modify the License. You may add Your own attribution
+ notices within Derivative Works that You distribute, alongside
+ or as an addendum to the NOTICE text from the Work, provided
+ that such additional attribution notices cannot be construed
+ as modifying the License.
+
+ You may add Your own copyright statement to Your modifications and
+ may provide additional or different license terms and conditions
+ for use, reproduction, or distribution of Your modifications, or
+ for any such Derivative Works as a whole, provided Your use,
+ reproduction, and distribution of the Work otherwise complies with
+ the conditions stated in this License.
+
+ 5. Submission of Contributions. Unless You explicitly state otherwise,
+ any Contribution intentionally submitted for inclusion in the Work
+ by You to the Licensor shall be under the terms and conditions of
+ this License, without any additional terms or conditions.
+ Notwithstanding the above, nothing herein shall supersede or modify
+ the terms of any separate license agreement you may have executed
+ with Licensor regarding such Contributions.
+
+ 6. Trademarks. This License does not grant permission to use the trade
+ names, trademarks, service marks, or product names of the Licensor,
+ except as required for reasonable and customary use in describing the
+ origin of the Work and reproducing the content of the NOTICE file.
+
+ 7. Disclaimer of Warranty. Unless required by applicable law or
+ agreed to in writing, Licensor provides the Work (and each
+ Contributor provides its Contributions) on an "AS IS" BASIS,
+ WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or
+ implied, including, without limitation, any warranties or conditions
+ of TITLE, NON-INFRINGEMENT, MERCHANTABILITY, or FITNESS FOR A
+ PARTICULAR PURPOSE. You are solely responsible for determining the
+ appropriateness of using or redistributing the Work and assume any
+ risks associated with Your exercise of permissions under this License.
+
+ 8. Limitation of Liability. In no event and under no legal theory,
+ whether in tort (including negligence), contract, or otherwise,
+ unless required by applicable law (such as deliberate and grossly
+ negligent acts) or agreed to in writing, shall any Contributor be
+ liable to You for damages, including any direct, indirect, special,
+ incidental, or consequential damages of any character arising as a
+ result of this License or out of the use or inability to use the
+ Work (including but not limited to damages for loss of goodwill,
+ work stoppage, computer failure or malfunction, or any and all
+ other commercial damages or losses), even if such Contributor
+ has been advised of the possibility of such damages.
+
+ 9. Accepting Warranty or Additional Liability. While redistributing
+ the Work or Derivative Works thereof, You may choose to offer,
+ and charge a fee for, acceptance of support, warranty, indemnity,
+ or other liability obligations and/or rights consistent with this
+ License. However, in accepting such obligations, You may act only
+ on Your own behalf and on Your sole responsibility, not on behalf
+ of any other Contributor, and only if You agree to indemnify,
+ defend, and hold each Contributor harmless for any liability
+ incurred by, or claims asserted against, such Contributor by reason
+ of your accepting any such warranty or additional liability.
+
+ END OF TERMS AND CONDITIONS
+
diff --git a/src/src/Notes-master/README b/src/src/Notes-master/README
new file mode 100644
index 0000000..fc0d824
--- /dev/null
+++ b/src/src/Notes-master/README
@@ -0,0 +1,23 @@
+[中文]
+
+1. MiCode便签是小米便签的社区开源版,由MIUI团队(www.miui.com) 发起并贡献第一批代码,遵循NOTICE文件所描述的开源协议,
+ 今后为MiCode社区(www.micode.net) 拥有,并由社区发布和维护。
+
+2. Bug反馈和跟踪,请访问Github,
+ https://github.com/MiCode/Notes/issues?sort=created&direction=desc&state=open
+
+3. 功能建议和综合讨论,请访问MiCode,
+ http://micode.net/forum.php?mod=forumdisplay&fid=38
+
+
+[English]
+
+1. MiCode Notes is open source edition of XM notepad, it's first initiated and sponsored by MIUI team (www.miui.com).
+ It's opened under license described by NOTICE file. It's owned by the MiCode community (www.micode.net). In future,
+ the MiCode community will release and maintain this project.
+
+2. Regarding issue tracking, please visit Github,
+ https://github.com/MiCode/Notes/issues?sort=created&direction=desc&state=open
+
+3. Regarding feature request and general discussion, please visit Micode forum,
+ http://micode.net/forum.php?mod=forumdisplay&fid=38
diff --git a/src/src/Notes-master/res/color/primary_text_dark.xml b/src/src/Notes-master/res/color/primary_text_dark.xml
new file mode 100644
index 0000000..7c85459
--- /dev/null
+++ b/src/src/Notes-master/res/color/primary_text_dark.xml
@@ -0,0 +1,22 @@
+
+
+
+
+
+
+
+
+
\ No newline at end of file
diff --git a/src/src/Notes-master/res/color/secondary_text_dark.xml b/src/src/Notes-master/res/color/secondary_text_dark.xml
new file mode 100644
index 0000000..c1c2384
--- /dev/null
+++ b/src/src/Notes-master/res/color/secondary_text_dark.xml
@@ -0,0 +1,20 @@
+
+
+
+
+
+
+
\ No newline at end of file
diff --git a/src/src/Notes-master/res/drawable-hdpi/bg_btn_set_color.png b/src/src/Notes-master/res/drawable-hdpi/bg_btn_set_color.png
new file mode 100644
index 0000000..5eb5d44
Binary files /dev/null and b/src/src/Notes-master/res/drawable-hdpi/bg_btn_set_color.png differ
diff --git a/src/src/Notes-master/res/drawable-hdpi/bg_color_btn_mask.png b/src/src/Notes-master/res/drawable-hdpi/bg_color_btn_mask.png
new file mode 100644
index 0000000..100db77
Binary files /dev/null and b/src/src/Notes-master/res/drawable-hdpi/bg_color_btn_mask.png differ
diff --git a/src/src/Notes-master/res/drawable-hdpi/call_record.png b/src/src/Notes-master/res/drawable-hdpi/call_record.png
new file mode 100644
index 0000000..fb88ca4
Binary files /dev/null and b/src/src/Notes-master/res/drawable-hdpi/call_record.png differ
diff --git a/src/src/Notes-master/res/drawable-hdpi/clock.png b/src/src/Notes-master/res/drawable-hdpi/clock.png
new file mode 100644
index 0000000..5f2ae9a
Binary files /dev/null and b/src/src/Notes-master/res/drawable-hdpi/clock.png differ
diff --git a/src/src/Notes-master/res/drawable-hdpi/delete.png b/src/src/Notes-master/res/drawable-hdpi/delete.png
new file mode 100644
index 0000000..643de3e
Binary files /dev/null and b/src/src/Notes-master/res/drawable-hdpi/delete.png differ
diff --git a/src/src/Notes-master/res/drawable-hdpi/dropdown_icon.9.png b/src/src/Notes-master/res/drawable-hdpi/dropdown_icon.9.png
new file mode 100644
index 0000000..5525025
Binary files /dev/null and b/src/src/Notes-master/res/drawable-hdpi/dropdown_icon.9.png differ
diff --git a/src/src/Notes-master/res/drawable-hdpi/edit_blue.9.png b/src/src/Notes-master/res/drawable-hdpi/edit_blue.9.png
new file mode 100644
index 0000000..55a1856
Binary files /dev/null and b/src/src/Notes-master/res/drawable-hdpi/edit_blue.9.png differ
diff --git a/src/src/Notes-master/res/drawable-hdpi/edit_green.9.png b/src/src/Notes-master/res/drawable-hdpi/edit_green.9.png
new file mode 100644
index 0000000..2cb2d60
Binary files /dev/null and b/src/src/Notes-master/res/drawable-hdpi/edit_green.9.png differ
diff --git a/src/src/Notes-master/res/drawable-hdpi/edit_red.9.png b/src/src/Notes-master/res/drawable-hdpi/edit_red.9.png
new file mode 100644
index 0000000..bae944a
Binary files /dev/null and b/src/src/Notes-master/res/drawable-hdpi/edit_red.9.png differ
diff --git a/src/src/Notes-master/res/drawable-hdpi/edit_title_blue.9.png b/src/src/Notes-master/res/drawable-hdpi/edit_title_blue.9.png
new file mode 100644
index 0000000..96e6092
Binary files /dev/null and b/src/src/Notes-master/res/drawable-hdpi/edit_title_blue.9.png differ
diff --git a/src/src/Notes-master/res/drawable-hdpi/edit_title_green.9.png b/src/src/Notes-master/res/drawable-hdpi/edit_title_green.9.png
new file mode 100644
index 0000000..08d8644
Binary files /dev/null and b/src/src/Notes-master/res/drawable-hdpi/edit_title_green.9.png differ
diff --git a/src/src/Notes-master/res/drawable-hdpi/edit_title_red.9.png b/src/src/Notes-master/res/drawable-hdpi/edit_title_red.9.png
new file mode 100644
index 0000000..9c430e5
Binary files /dev/null and b/src/src/Notes-master/res/drawable-hdpi/edit_title_red.9.png differ
diff --git a/src/src/Notes-master/res/drawable-hdpi/edit_title_white.9.png b/src/src/Notes-master/res/drawable-hdpi/edit_title_white.9.png
new file mode 100644
index 0000000..19e8d95
Binary files /dev/null and b/src/src/Notes-master/res/drawable-hdpi/edit_title_white.9.png differ
diff --git a/src/src/Notes-master/res/drawable-hdpi/edit_title_yellow.9.png b/src/src/Notes-master/res/drawable-hdpi/edit_title_yellow.9.png
new file mode 100644
index 0000000..bf8f580
Binary files /dev/null and b/src/src/Notes-master/res/drawable-hdpi/edit_title_yellow.9.png differ
diff --git a/src/src/Notes-master/res/drawable-hdpi/edit_white.9.png b/src/src/Notes-master/res/drawable-hdpi/edit_white.9.png
new file mode 100644
index 0000000..918f7a6
Binary files /dev/null and b/src/src/Notes-master/res/drawable-hdpi/edit_white.9.png differ
diff --git a/src/src/Notes-master/res/drawable-hdpi/edit_yellow.9.png b/src/src/Notes-master/res/drawable-hdpi/edit_yellow.9.png
new file mode 100644
index 0000000..10cb642
Binary files /dev/null and b/src/src/Notes-master/res/drawable-hdpi/edit_yellow.9.png differ
diff --git a/src/src/Notes-master/res/drawable-hdpi/font_large.png b/src/src/Notes-master/res/drawable-hdpi/font_large.png
new file mode 100644
index 0000000..78cf2e6
Binary files /dev/null and b/src/src/Notes-master/res/drawable-hdpi/font_large.png differ
diff --git a/src/src/Notes-master/res/drawable-hdpi/font_normal.png b/src/src/Notes-master/res/drawable-hdpi/font_normal.png
new file mode 100644
index 0000000..9de7ced
Binary files /dev/null and b/src/src/Notes-master/res/drawable-hdpi/font_normal.png differ
diff --git a/src/src/Notes-master/res/drawable-hdpi/font_size_selector_bg.9.png b/src/src/Notes-master/res/drawable-hdpi/font_size_selector_bg.9.png
new file mode 100644
index 0000000..be8e64c
Binary files /dev/null and b/src/src/Notes-master/res/drawable-hdpi/font_size_selector_bg.9.png differ
diff --git a/src/src/Notes-master/res/drawable-hdpi/font_small.png b/src/src/Notes-master/res/drawable-hdpi/font_small.png
new file mode 100644
index 0000000..d3ff104
Binary files /dev/null and b/src/src/Notes-master/res/drawable-hdpi/font_small.png differ
diff --git a/src/src/Notes-master/res/drawable-hdpi/font_super.png b/src/src/Notes-master/res/drawable-hdpi/font_super.png
new file mode 100644
index 0000000..85b13a1
Binary files /dev/null and b/src/src/Notes-master/res/drawable-hdpi/font_super.png differ
diff --git a/src/src/Notes-master/res/drawable-hdpi/icon_app.png b/src/src/Notes-master/res/drawable-hdpi/icon_app.png
new file mode 100644
index 0000000..418aadc
Binary files /dev/null and b/src/src/Notes-master/res/drawable-hdpi/icon_app.png differ
diff --git a/src/src/Notes-master/res/drawable-hdpi/list_background.png b/src/src/Notes-master/res/drawable-hdpi/list_background.png
new file mode 100644
index 0000000..087e1f9
Binary files /dev/null and b/src/src/Notes-master/res/drawable-hdpi/list_background.png differ
diff --git a/src/src/Notes-master/res/drawable-hdpi/list_blue_down.9.png b/src/src/Notes-master/res/drawable-hdpi/list_blue_down.9.png
new file mode 100644
index 0000000..b88eebf
Binary files /dev/null and b/src/src/Notes-master/res/drawable-hdpi/list_blue_down.9.png differ
diff --git a/src/src/Notes-master/res/drawable-hdpi/list_blue_middle.9.png b/src/src/Notes-master/res/drawable-hdpi/list_blue_middle.9.png
new file mode 100644
index 0000000..96b1c8b
Binary files /dev/null and b/src/src/Notes-master/res/drawable-hdpi/list_blue_middle.9.png differ
diff --git a/src/src/Notes-master/res/drawable-hdpi/list_blue_single.9.png b/src/src/Notes-master/res/drawable-hdpi/list_blue_single.9.png
new file mode 100644
index 0000000..d7e7206
Binary files /dev/null and b/src/src/Notes-master/res/drawable-hdpi/list_blue_single.9.png differ
diff --git a/src/src/Notes-master/res/drawable-hdpi/list_blue_up.9.png b/src/src/Notes-master/res/drawable-hdpi/list_blue_up.9.png
new file mode 100644
index 0000000..632e88c
Binary files /dev/null and b/src/src/Notes-master/res/drawable-hdpi/list_blue_up.9.png differ
diff --git a/src/src/Notes-master/res/drawable-hdpi/list_folder.9.png b/src/src/Notes-master/res/drawable-hdpi/list_folder.9.png
new file mode 100644
index 0000000..829f61b
Binary files /dev/null and b/src/src/Notes-master/res/drawable-hdpi/list_folder.9.png differ
diff --git a/src/src/Notes-master/res/drawable-hdpi/list_footer_bg.9.png b/src/src/Notes-master/res/drawable-hdpi/list_footer_bg.9.png
new file mode 100644
index 0000000..5325c25
Binary files /dev/null and b/src/src/Notes-master/res/drawable-hdpi/list_footer_bg.9.png differ
diff --git a/src/src/Notes-master/res/drawable-hdpi/list_green_down.9.png b/src/src/Notes-master/res/drawable-hdpi/list_green_down.9.png
new file mode 100644
index 0000000..64a39d9
Binary files /dev/null and b/src/src/Notes-master/res/drawable-hdpi/list_green_down.9.png differ
diff --git a/src/src/Notes-master/res/drawable-hdpi/list_green_middle.9.png b/src/src/Notes-master/res/drawable-hdpi/list_green_middle.9.png
new file mode 100644
index 0000000..897325a
Binary files /dev/null and b/src/src/Notes-master/res/drawable-hdpi/list_green_middle.9.png differ
diff --git a/src/src/Notes-master/res/drawable-hdpi/list_green_single.9.png b/src/src/Notes-master/res/drawable-hdpi/list_green_single.9.png
new file mode 100644
index 0000000..c83405f
Binary files /dev/null and b/src/src/Notes-master/res/drawable-hdpi/list_green_single.9.png differ
diff --git a/src/src/Notes-master/res/drawable-hdpi/list_green_up.9.png b/src/src/Notes-master/res/drawable-hdpi/list_green_up.9.png
new file mode 100644
index 0000000..141f9e1
Binary files /dev/null and b/src/src/Notes-master/res/drawable-hdpi/list_green_up.9.png differ
diff --git a/src/src/Notes-master/res/drawable-hdpi/list_red_down.9.png b/src/src/Notes-master/res/drawable-hdpi/list_red_down.9.png
new file mode 100644
index 0000000..4224309
Binary files /dev/null and b/src/src/Notes-master/res/drawable-hdpi/list_red_down.9.png differ
diff --git a/src/src/Notes-master/res/drawable-hdpi/list_red_middle.9.png b/src/src/Notes-master/res/drawable-hdpi/list_red_middle.9.png
new file mode 100644
index 0000000..9988f17
Binary files /dev/null and b/src/src/Notes-master/res/drawable-hdpi/list_red_middle.9.png differ
diff --git a/src/src/Notes-master/res/drawable-hdpi/list_red_single.9.png b/src/src/Notes-master/res/drawable-hdpi/list_red_single.9.png
new file mode 100644
index 0000000..587c348
Binary files /dev/null and b/src/src/Notes-master/res/drawable-hdpi/list_red_single.9.png differ
diff --git a/src/src/Notes-master/res/drawable-hdpi/list_red_up.9.png b/src/src/Notes-master/res/drawable-hdpi/list_red_up.9.png
new file mode 100644
index 0000000..46b4757
Binary files /dev/null and b/src/src/Notes-master/res/drawable-hdpi/list_red_up.9.png differ
diff --git a/src/src/Notes-master/res/drawable-hdpi/list_white_down.9.png b/src/src/Notes-master/res/drawable-hdpi/list_white_down.9.png
new file mode 100644
index 0000000..29f9d8c
Binary files /dev/null and b/src/src/Notes-master/res/drawable-hdpi/list_white_down.9.png differ
diff --git a/src/src/Notes-master/res/drawable-hdpi/list_white_middle.9.png b/src/src/Notes-master/res/drawable-hdpi/list_white_middle.9.png
new file mode 100644
index 0000000..77a4ab4
Binary files /dev/null and b/src/src/Notes-master/res/drawable-hdpi/list_white_middle.9.png differ
diff --git a/src/src/Notes-master/res/drawable-hdpi/list_white_single.9.png b/src/src/Notes-master/res/drawable-hdpi/list_white_single.9.png
new file mode 100644
index 0000000..3e79189
Binary files /dev/null and b/src/src/Notes-master/res/drawable-hdpi/list_white_single.9.png differ
diff --git a/src/src/Notes-master/res/drawable-hdpi/list_white_up.9.png b/src/src/Notes-master/res/drawable-hdpi/list_white_up.9.png
new file mode 100644
index 0000000..e23cd5c
Binary files /dev/null and b/src/src/Notes-master/res/drawable-hdpi/list_white_up.9.png differ
diff --git a/src/src/Notes-master/res/drawable-hdpi/list_yellow_down.9.png b/src/src/Notes-master/res/drawable-hdpi/list_yellow_down.9.png
new file mode 100644
index 0000000..31cfc1e
Binary files /dev/null and b/src/src/Notes-master/res/drawable-hdpi/list_yellow_down.9.png differ
diff --git a/src/src/Notes-master/res/drawable-hdpi/list_yellow_middle.9.png b/src/src/Notes-master/res/drawable-hdpi/list_yellow_middle.9.png
new file mode 100644
index 0000000..b6549b2
Binary files /dev/null and b/src/src/Notes-master/res/drawable-hdpi/list_yellow_middle.9.png differ
diff --git a/src/src/Notes-master/res/drawable-hdpi/list_yellow_single.9.png b/src/src/Notes-master/res/drawable-hdpi/list_yellow_single.9.png
new file mode 100644
index 0000000..3faf507
Binary files /dev/null and b/src/src/Notes-master/res/drawable-hdpi/list_yellow_single.9.png differ
diff --git a/src/src/Notes-master/res/drawable-hdpi/list_yellow_up.9.png b/src/src/Notes-master/res/drawable-hdpi/list_yellow_up.9.png
new file mode 100644
index 0000000..4ae791c
Binary files /dev/null and b/src/src/Notes-master/res/drawable-hdpi/list_yellow_up.9.png differ
diff --git a/src/src/Notes-master/res/drawable-hdpi/menu_delete.png b/src/src/Notes-master/res/drawable-hdpi/menu_delete.png
new file mode 100644
index 0000000..ccdfc4b
Binary files /dev/null and b/src/src/Notes-master/res/drawable-hdpi/menu_delete.png differ
diff --git a/src/src/Notes-master/res/drawable-hdpi/menu_move.png b/src/src/Notes-master/res/drawable-hdpi/menu_move.png
new file mode 100644
index 0000000..1140b71
Binary files /dev/null and b/src/src/Notes-master/res/drawable-hdpi/menu_move.png differ
diff --git a/src/src/Notes-master/res/drawable-hdpi/new_note_normal.png b/src/src/Notes-master/res/drawable-hdpi/new_note_normal.png
new file mode 100644
index 0000000..e24e0d1
Binary files /dev/null and b/src/src/Notes-master/res/drawable-hdpi/new_note_normal.png differ
diff --git a/src/src/Notes-master/res/drawable-hdpi/new_note_pressed.png b/src/src/Notes-master/res/drawable-hdpi/new_note_pressed.png
new file mode 100644
index 0000000..c748936
Binary files /dev/null and b/src/src/Notes-master/res/drawable-hdpi/new_note_pressed.png differ
diff --git a/src/src/Notes-master/res/drawable-hdpi/note_edit_color_selector_panel.png b/src/src/Notes-master/res/drawable-hdpi/note_edit_color_selector_panel.png
new file mode 100644
index 0000000..fc49552
Binary files /dev/null and b/src/src/Notes-master/res/drawable-hdpi/note_edit_color_selector_panel.png differ
diff --git a/src/src/Notes-master/res/drawable-hdpi/notification.png b/src/src/Notes-master/res/drawable-hdpi/notification.png
new file mode 100644
index 0000000..b13ab4a
Binary files /dev/null and b/src/src/Notes-master/res/drawable-hdpi/notification.png differ
diff --git a/src/src/Notes-master/res/drawable-hdpi/search_result.png b/src/src/Notes-master/res/drawable-hdpi/search_result.png
new file mode 100644
index 0000000..ff2befd
Binary files /dev/null and b/src/src/Notes-master/res/drawable-hdpi/search_result.png differ
diff --git a/src/src/Notes-master/res/drawable-hdpi/selected.png b/src/src/Notes-master/res/drawable-hdpi/selected.png
new file mode 100644
index 0000000..b889bef
Binary files /dev/null and b/src/src/Notes-master/res/drawable-hdpi/selected.png differ
diff --git a/src/src/Notes-master/res/drawable-hdpi/title_alert.png b/src/src/Notes-master/res/drawable-hdpi/title_alert.png
new file mode 100644
index 0000000..544ee9c
Binary files /dev/null and b/src/src/Notes-master/res/drawable-hdpi/title_alert.png differ
diff --git a/src/src/Notes-master/res/drawable-hdpi/title_bar_bg.9.png b/src/src/Notes-master/res/drawable-hdpi/title_bar_bg.9.png
new file mode 100644
index 0000000..eb6bff0
Binary files /dev/null and b/src/src/Notes-master/res/drawable-hdpi/title_bar_bg.9.png differ
diff --git a/src/src/Notes-master/res/drawable-hdpi/widget_2x_blue.png b/src/src/Notes-master/res/drawable-hdpi/widget_2x_blue.png
new file mode 100644
index 0000000..a1707f4
Binary files /dev/null and b/src/src/Notes-master/res/drawable-hdpi/widget_2x_blue.png differ
diff --git a/src/src/Notes-master/res/drawable-hdpi/widget_2x_green.png b/src/src/Notes-master/res/drawable-hdpi/widget_2x_green.png
new file mode 100644
index 0000000..f86886c
Binary files /dev/null and b/src/src/Notes-master/res/drawable-hdpi/widget_2x_green.png differ
diff --git a/src/src/Notes-master/res/drawable-hdpi/widget_2x_red.png b/src/src/Notes-master/res/drawable-hdpi/widget_2x_red.png
new file mode 100644
index 0000000..0e66c29
Binary files /dev/null and b/src/src/Notes-master/res/drawable-hdpi/widget_2x_red.png differ
diff --git a/src/src/Notes-master/res/drawable-hdpi/widget_2x_white.png b/src/src/Notes-master/res/drawable-hdpi/widget_2x_white.png
new file mode 100644
index 0000000..5f0619a
Binary files /dev/null and b/src/src/Notes-master/res/drawable-hdpi/widget_2x_white.png differ
diff --git a/src/src/Notes-master/res/drawable-hdpi/widget_2x_yellow.png b/src/src/Notes-master/res/drawable-hdpi/widget_2x_yellow.png
new file mode 100644
index 0000000..12d1c2b
Binary files /dev/null and b/src/src/Notes-master/res/drawable-hdpi/widget_2x_yellow.png differ
diff --git a/src/src/Notes-master/res/drawable-hdpi/widget_4x_blue.png b/src/src/Notes-master/res/drawable-hdpi/widget_4x_blue.png
new file mode 100644
index 0000000..9183738
Binary files /dev/null and b/src/src/Notes-master/res/drawable-hdpi/widget_4x_blue.png differ
diff --git a/src/src/Notes-master/res/drawable-hdpi/widget_4x_green.png b/src/src/Notes-master/res/drawable-hdpi/widget_4x_green.png
new file mode 100644
index 0000000..fa8b452
Binary files /dev/null and b/src/src/Notes-master/res/drawable-hdpi/widget_4x_green.png differ
diff --git a/src/src/Notes-master/res/drawable-hdpi/widget_4x_red.png b/src/src/Notes-master/res/drawable-hdpi/widget_4x_red.png
new file mode 100644
index 0000000..62de074
Binary files /dev/null and b/src/src/Notes-master/res/drawable-hdpi/widget_4x_red.png differ
diff --git a/src/src/Notes-master/res/drawable-hdpi/widget_4x_white.png b/src/src/Notes-master/res/drawable-hdpi/widget_4x_white.png
new file mode 100644
index 0000000..a37d67c
Binary files /dev/null and b/src/src/Notes-master/res/drawable-hdpi/widget_4x_white.png differ
diff --git a/src/src/Notes-master/res/drawable-hdpi/widget_4x_yellow.png b/src/src/Notes-master/res/drawable-hdpi/widget_4x_yellow.png
new file mode 100644
index 0000000..d7c5fa4
Binary files /dev/null and b/src/src/Notes-master/res/drawable-hdpi/widget_4x_yellow.png differ
diff --git a/src/src/Notes-master/res/drawable/new_note.xml b/src/src/Notes-master/res/drawable/new_note.xml
new file mode 100644
index 0000000..2154ebc
--- /dev/null
+++ b/src/src/Notes-master/res/drawable/new_note.xml
@@ -0,0 +1,23 @@
+
+
+
+
+
+
+
+
diff --git a/src/src/Notes-master/res/layout/account_dialog_title.xml b/src/src/Notes-master/res/layout/account_dialog_title.xml
new file mode 100644
index 0000000..7717112
--- /dev/null
+++ b/src/src/Notes-master/res/layout/account_dialog_title.xml
@@ -0,0 +1,43 @@
+
+
+
+
+
+
+
+
+
+
+
\ No newline at end of file
diff --git a/src/src/Notes-master/res/layout/add_account_text.xml b/src/src/Notes-master/res/layout/add_account_text.xml
new file mode 100644
index 0000000..c799178
--- /dev/null
+++ b/src/src/Notes-master/res/layout/add_account_text.xml
@@ -0,0 +1,32 @@
+
+
+
+
+
+
+
+
\ No newline at end of file
diff --git a/src/src/Notes-master/res/layout/datetime_picker.xml b/src/src/Notes-master/res/layout/datetime_picker.xml
new file mode 100644
index 0000000..f10d592
--- /dev/null
+++ b/src/src/Notes-master/res/layout/datetime_picker.xml
@@ -0,0 +1,56 @@
+
+
+
+
+
+
+
+
+
+
+
+
\ No newline at end of file
diff --git a/src/src/Notes-master/res/layout/dialog_edit_text.xml b/src/src/Notes-master/res/layout/dialog_edit_text.xml
new file mode 100644
index 0000000..361b39a
--- /dev/null
+++ b/src/src/Notes-master/res/layout/dialog_edit_text.xml
@@ -0,0 +1,23 @@
+
+
+
+
+
\ No newline at end of file
diff --git a/src/src/Notes-master/res/layout/folder_list_item.xml b/src/src/Notes-master/res/layout/folder_list_item.xml
new file mode 100644
index 0000000..77e8148
--- /dev/null
+++ b/src/src/Notes-master/res/layout/folder_list_item.xml
@@ -0,0 +1,29 @@
+
+
+
+
+
+
+
+
\ No newline at end of file
diff --git a/src/src/Notes-master/res/layout/note_edit.xml b/src/src/Notes-master/res/layout/note_edit.xml
new file mode 100644
index 0000000..10b2aa7
--- /dev/null
+++ b/src/src/Notes-master/res/layout/note_edit.xml
@@ -0,0 +1,400 @@
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
diff --git a/src/src/Notes-master/res/layout/note_edit_list_item.xml b/src/src/Notes-master/res/layout/note_edit_list_item.xml
new file mode 100644
index 0000000..a885f9c
--- /dev/null
+++ b/src/src/Notes-master/res/layout/note_edit_list_item.xml
@@ -0,0 +1,39 @@
+
+
+
+
+
+
+
+
+
+
diff --git a/src/src/Notes-master/res/layout/note_item.xml b/src/src/Notes-master/res/layout/note_item.xml
new file mode 100644
index 0000000..d541f6a
--- /dev/null
+++ b/src/src/Notes-master/res/layout/note_item.xml
@@ -0,0 +1,78 @@
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
diff --git a/src/src/Notes-master/res/layout/note_list.xml b/src/src/Notes-master/res/layout/note_list.xml
new file mode 100644
index 0000000..6b25d38
--- /dev/null
+++ b/src/src/Notes-master/res/layout/note_list.xml
@@ -0,0 +1,58 @@
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
diff --git a/src/src/Notes-master/res/layout/note_list_dropdown_menu.xml b/src/src/Notes-master/res/layout/note_list_dropdown_menu.xml
new file mode 100644
index 0000000..3fa271d
--- /dev/null
+++ b/src/src/Notes-master/res/layout/note_list_dropdown_menu.xml
@@ -0,0 +1,32 @@
+
+
+
+
+
+
+
+
\ No newline at end of file
diff --git a/src/src/Notes-master/res/layout/note_list_footer.xml b/src/src/Notes-master/res/layout/note_list_footer.xml
new file mode 100644
index 0000000..5ca7b22
--- /dev/null
+++ b/src/src/Notes-master/res/layout/note_list_footer.xml
@@ -0,0 +1,24 @@
+
+
+
+
+
\ No newline at end of file
diff --git a/src/src/Notes-master/res/layout/settings_header.xml b/src/src/Notes-master/res/layout/settings_header.xml
new file mode 100644
index 0000000..5eb8c50
--- /dev/null
+++ b/src/src/Notes-master/res/layout/settings_header.xml
@@ -0,0 +1,41 @@
+
+
+
+
+
+
+
+
+
+
+
\ No newline at end of file
diff --git a/src/src/Notes-master/res/layout/widget_2x.xml b/src/src/Notes-master/res/layout/widget_2x.xml
new file mode 100644
index 0000000..55970ce
--- /dev/null
+++ b/src/src/Notes-master/res/layout/widget_2x.xml
@@ -0,0 +1,37 @@
+
+
+
+
+
+
+
+
diff --git a/src/src/Notes-master/res/layout/widget_4x.xml b/src/src/Notes-master/res/layout/widget_4x.xml
new file mode 100644
index 0000000..dc9bb51
--- /dev/null
+++ b/src/src/Notes-master/res/layout/widget_4x.xml
@@ -0,0 +1,39 @@
+
+
+
+
+
+
+
+
+
+
diff --git a/src/src/Notes-master/res/menu/call_note_edit.xml b/src/src/Notes-master/res/menu/call_note_edit.xml
new file mode 100644
index 0000000..02c0528
--- /dev/null
+++ b/src/src/Notes-master/res/menu/call_note_edit.xml
@@ -0,0 +1,48 @@
+
+
+
+
+
diff --git a/src/src/Notes-master/res/menu/call_record_folder.xml b/src/src/Notes-master/res/menu/call_record_folder.xml
new file mode 100644
index 0000000..c664346
--- /dev/null
+++ b/src/src/Notes-master/res/menu/call_record_folder.xml
@@ -0,0 +1,23 @@
+
+
+
+
+
diff --git a/src/src/Notes-master/res/menu/note_edit.xml b/src/src/Notes-master/res/menu/note_edit.xml
new file mode 100644
index 0000000..35cacd1
--- /dev/null
+++ b/src/src/Notes-master/res/menu/note_edit.xml
@@ -0,0 +1,52 @@
+
+
+
+
+
\ No newline at end of file
diff --git a/src/src/Notes-master/res/menu/note_list.xml b/src/src/Notes-master/res/menu/note_list.xml
new file mode 100644
index 0000000..42ea736
--- /dev/null
+++ b/src/src/Notes-master/res/menu/note_list.xml
@@ -0,0 +1,39 @@
+
+
+
+
+
diff --git a/src/src/Notes-master/res/menu/note_list_dropdown.xml b/src/src/Notes-master/res/menu/note_list_dropdown.xml
new file mode 100644
index 0000000..7cbaadc
--- /dev/null
+++ b/src/src/Notes-master/res/menu/note_list_dropdown.xml
@@ -0,0 +1,20 @@
+
+
+
+
+
\ No newline at end of file
diff --git a/src/src/Notes-master/res/menu/note_list_options.xml b/src/src/Notes-master/res/menu/note_list_options.xml
new file mode 100644
index 0000000..daac008
--- /dev/null
+++ b/src/src/Notes-master/res/menu/note_list_options.xml
@@ -0,0 +1,31 @@
+
+
+
+
+
\ No newline at end of file
diff --git a/src/src/Notes-master/res/menu/sub_folder.xml b/src/src/Notes-master/res/menu/sub_folder.xml
new file mode 100644
index 0000000..b00de26
--- /dev/null
+++ b/src/src/Notes-master/res/menu/sub_folder.xml
@@ -0,0 +1,24 @@
+
+
+
+
+
\ No newline at end of file
diff --git a/src/src/Notes-master/res/raw-zh-rCN/introduction b/src/src/Notes-master/res/raw-zh-rCN/introduction
new file mode 100644
index 0000000..7188359
--- /dev/null
+++ b/src/src/Notes-master/res/raw-zh-rCN/introduction
@@ -0,0 +1,7 @@
+欢迎使用MIUI便签!
+
+ 无论从软件中直接添加,还是从桌面拖出widget,MIUI便签能让你快速建立和保存便签;
+
+ 除了调整文字大小、便签背景、文件夹等基础功能外,你会发现MIUI便签也提供了清单模式、便签提醒、软件加密、导出到SD卡、同步google task的高级功能,让你的生活记录更加美好和安全;
+
+ 来分享你的使用体验吧:http://www.miui.com/index.php
diff --git a/src/src/Notes-master/res/raw/introduction b/src/src/Notes-master/res/raw/introduction
new file mode 100644
index 0000000..269cf7b
--- /dev/null
+++ b/src/src/Notes-master/res/raw/introduction
@@ -0,0 +1 @@
+Welcome to use MIUI notes!
\ No newline at end of file
diff --git a/src/src/Notes-master/res/values-zh-rCN/arrays.xml b/src/src/Notes-master/res/values-zh-rCN/arrays.xml
new file mode 100644
index 0000000..a092386
--- /dev/null
+++ b/src/src/Notes-master/res/values-zh-rCN/arrays.xml
@@ -0,0 +1,23 @@
+
+
+
+
+
+
+ 短信
+ 邮件
+
+
\ No newline at end of file
diff --git a/src/src/Notes-master/res/values-zh-rCN/strings.xml b/src/src/Notes-master/res/values-zh-rCN/strings.xml
new file mode 100644
index 0000000..09f75ed
--- /dev/null
+++ b/src/src/Notes-master/res/values-zh-rCN/strings.xml
@@ -0,0 +1,126 @@
+
+
+
+
+
+ 便签
+ 便签2x2
+ 便签4x4
+ 没有关联内容,点击新建便签。
+ 访客模式下,便签内容不可见
+ ...
+ 新建便签
+ 成功删除提醒
+ 创建提醒
+ 已过期
+ yyyyMMdd
+ MM月dd日 kk:mm
+ 知道了
+ 查看
+ 呼叫电话
+ 发送邮件
+ 浏览网页
+ 打开地图
+
+ 新建文件夹
+ 导出文本
+ 同步
+ 取消同步
+ 设置
+ 搜索
+ 删除
+ 移动到文件夹
+ 选中了 %d 项
+ 没有选中项,操作无效
+ 全选
+ 取消全选
+ 文字大小
+ 小
+ 正常
+ 大
+ 超大
+ 进入清单模式
+ 退出清单模式
+ 查看文件夹
+ 刪除文件夹
+ 修改文件夹名称
+ 文件夹 %1$s 已存在,请重新命名
+ 分享
+ 发送到桌面
+ 提醒我
+ 删除提醒
+ 选择文件夹
+ 上一级文件夹
+ 已添加到桌面
+ 删除
+ 确认要删除所选的 %d 条便签吗?
+ 确认要删除该条便签吗?
+ 确认删除文件夹及所包含的便签吗?
+ 已将所选 %1$d 条便签移到 %2$s 文件夹
+
+ SD卡被占用,不能操作
+ 导出文本时发生错误,请检查SD卡
+ 要查看的便签不存在
+ 不能为空便签设置闹钟提醒
+ 不能将空便签发送到桌面
+ 导出成功
+ 导出失败
+ 已将文本文件(%1$s)输出至SD卡(%2$s)目录
+
+ 同步便签...
+ 同步成功
+ 同步失败
+ 同步已取消
+ 与%1$s同步成功
+ 同步失败,请检查网络和帐号设置
+ 同步失败,发生内部错误
+ 同步已取消
+ 登录%1$s...
+ 正在获取服务器便签列表...
+ 正在同步本地便签...
+
+ 设置
+ 同步账号
+ 与google task同步便签记录
+ 上次同步于 %1$s
+ 添加账号
+ 更换账号
+ 删除账号
+ 取消
+ 立即同步
+ 取消同步
+ 当前帐号 %1$s
+ 如更换同步帐号,过去的帐号同步信息将被清空,再次切换的同时可能会造成数据重复
+ 同步便签
+ 请选择google帐号,便签将与该帐号的google task内容同步。
+ 正在同步中,不能修改同步帐号
+ 同步帐号已设置为%1$s
+ 新建便签背景颜色随机
+ 删除
+ 通话便签
+ 请输入名称
+ 正在搜索便签
+ 搜索便签
+ 便签中的文字
+ 便签
+ 设置
+ 取消
+
+ %1$s 条符合“%2$s”的搜索结果
+
+
+
diff --git a/src/src/Notes-master/res/values-zh-rTW/arrays.xml b/src/src/Notes-master/res/values-zh-rTW/arrays.xml
new file mode 100644
index 0000000..5297209
--- /dev/null
+++ b/src/src/Notes-master/res/values-zh-rTW/arrays.xml
@@ -0,0 +1,23 @@
+
+
+
+
+
+
+ 短信
+ 郵件
+
+
\ No newline at end of file
diff --git a/src/src/Notes-master/res/values-zh-rTW/strings.xml b/src/src/Notes-master/res/values-zh-rTW/strings.xml
new file mode 100644
index 0000000..3c41894
--- /dev/null
+++ b/src/src/Notes-master/res/values-zh-rTW/strings.xml
@@ -0,0 +1,127 @@
+
+
+
+
+
+ 便簽
+ 便簽2x2
+ 便簽4x4
+ 沒有關聯內容,點擊新建便簽。
+ 訪客模式下,便籤內容不可見
+ ...
+ 新建便簽
+ 成功刪除提醒
+ 創建提醒
+ 已過期
+ yyyyMMdd
+ MM月dd日 kk:mm
+ 知道了
+ 查看
+ 呼叫電話
+ 發送郵件
+ 浏覽網頁
+ 打開地圖
+ 已將所選 %1$d 便籤移到 %2$s 文件夾
+
+ 新建文件夾
+ 導出文本
+ 同步
+ 取消同步
+ 設置
+ 搜尋
+ 刪除
+ 移動到文件夾
+ 選中了 %d 項
+ 沒有選中項,操作無效
+ 全選
+ 取消全選
+ 文字大小
+ 小
+ 正常
+ 大
+ 超大
+ 進入清單模式
+ 退出清單模式
+ 查看文件夾
+ 刪除文件夾
+ 修改文件夾名稱
+ 文件夾 %1$s 已存在,請重新命名
+ 分享
+ 發送到桌面
+ 提醒我
+ 刪除提醒
+ 選擇文件夾
+ 上一級文件夾
+ 已添加到桌面
+ 刪除
+ 确认要刪除所選的 %d 條便籤嗎?
+ 确认要删除該條便籤嗎?
+ 確認刪除檔夾及所包含的便簽嗎?
+ SD卡被佔用,不能操作
+ 導出TXT時發生錯誤,請檢查SD卡
+ 要查看的便籤不存在
+ 不能爲空便籤設置鬧鐘提醒
+ 不能將空便籤發送到桌面
+ 導出成功
+ 導出失敗
+ 已將文本文件(%1$s)導出至SD(%2$s)目錄
+
+ 同步便簽...
+ 同步成功
+ 同步失敗
+ 同步已取消
+ 與%1$s同步成功
+ 同步失敗,請檢查網絡和帳號設置
+ 同步失敗,發生內部錯誤
+ 同步已取消
+ 登陸%1$s...
+ 正在獲取服務器便籤列表...
+ 正在同步本地便籤...
+
+ 設置
+ 同步賬號
+ 与google task同步便簽記錄
+ 上次同步于 %1$s
+ 添加賬號
+ 更換賬號
+ 刪除賬號
+ 取消
+ 立即同步
+ 取消同步
+ 當前帳號 %1$s
+ 如更換同步帳號,過去的帳號同步信息將被清空,再次切換的同時可能會造成數據重復
+ 同步便簽
+ 請選擇google帳號,便簽將與該帳號的google task內容同步。
+ 正在同步中,不能修改同步帳號
+ 同步帳號已設置為%1$s
+ 新建便籤背景顏色隨機
+
+ 刪除
+ 通話便籤
+ 請輸入名稱
+
+ 正在搜索便籤
+ 搜索便籤
+ 便籤中的文字
+ 便籤
+ 設置
+ 取消
+
+ %1$s 條符合”%2$s“的搜尋結果
+
+
+
diff --git a/src/src/Notes-master/res/values/arrays.xml b/src/src/Notes-master/res/values/arrays.xml
new file mode 100644
index 0000000..e00210b
--- /dev/null
+++ b/src/src/Notes-master/res/values/arrays.xml
@@ -0,0 +1,31 @@
+
+
+
+
+
+
+
+ -%s
+ --%s
+ --%s
+ --%s
+
+
+
+ Messaging
+ Email
+
+
\ No newline at end of file
diff --git a/src/src/Notes-master/res/values/colors.xml b/src/src/Notes-master/res/values/colors.xml
new file mode 100644
index 0000000..123ffbf
--- /dev/null
+++ b/src/src/Notes-master/res/values/colors.xml
@@ -0,0 +1,20 @@
+
+
+
+
+
+ #335b5b5b
+
diff --git a/src/src/Notes-master/res/values/dimens.xml b/src/src/Notes-master/res/values/dimens.xml
new file mode 100644
index 0000000..194e84f
--- /dev/null
+++ b/src/src/Notes-master/res/values/dimens.xml
@@ -0,0 +1,24 @@
+
+
+
+
+
+ 33sp
+ 26sp
+ 20sp
+ 17sp
+ 14sp
+
\ No newline at end of file
diff --git a/src/src/Notes-master/res/values/strings.xml b/src/src/Notes-master/res/values/strings.xml
new file mode 100644
index 0000000..55df868
--- /dev/null
+++ b/src/src/Notes-master/res/values/strings.xml
@@ -0,0 +1,135 @@
+
+
+
+
+
+ Notes
+ Notes 2x2
+ Notes 4x4
+ No associated note found, click to create associated note.
+ Privacy mode,can not see note content
+ ...
+ Add note
+ Delete reminder successfully
+ Set reminder
+ Expired
+ yyyyMMdd
+ MMMd kk:mm
+ Got it
+ Take a look
+ Call
+ Send email
+ Browse web
+ Open map
+
+ /MIUI/notes/
+ notes_%s.txt
+
+ (%d)
+ New Folder
+ Export text
+ Sync
+ Cancel syncing
+ Settings
+ Search
+ Delete
+ Move to folder
+ %d selected
+ Nothing selected, the operation is invalid
+ Select all
+ Deselect all
+ Font size
+ Small
+ Medium
+ Large
+ Super
+ Enter check list
+ Leave check list
+ View folder
+ Delete folder
+ Change folder name
+ The folder %1$s exist, please rename
+ Share
+ Send to home
+ Remind me
+ Delete reminder
+ Select folder
+ Parent folder
+ Note added to home
+ Confirm to delete folder and its notes?
+ Delete selected notes
+ Confirm to delete the selected %d notes?
+ Confirm to delete this note?
+ Have moved selected %1$d notes to %2$s folder
+
+ SD card busy, not available now
+ Export failed, please check SD card
+ The note is not exist
+ Sorry, can not set clock on empty note
+ Sorry, can not send and empty note to home
+ Export successful
+ Export fail
+ Export text file (%1$s) to SD (%2$s) directory
+
+ Syncing notes...
+ Sync is successful
+ Sync is failed
+ Sync is canceled
+ Sync is successful with account %1$s
+ Sync failed, please check network and account settings
+ Sync failed, internal error occurs
+ Sync is canceled
+ Logging into %1$s...
+ Getting remote note list...
+ Synchronize local notes with Google Task...
+
+ Settings
+ Sync account
+ Sync notes with google task
+ Last sync time %1$s
+ yyyy-MM-dd hh:mm:ss
+ Add account
+ Change sync account
+ Remove sync account
+ Cancel
+ Sync immediately
+ Cancel syncing
+ Current account %1$s
+ All sync related information will be deleted, which may result in duplicated items sometime
+ Sync notes
+ Please select a google account. Local notes will be synced with google task.
+ Cannot change the account because sync is in progress
+ %1$s has been set as the sync account
+ New note background color random
+
+ Delete
+ Call notes
+ Input name
+
+ Searching Notes
+ Search notes
+ Text in your notes
+ Notes
+ set
+ cancel
+
+ %1$s result for \"%2$s\"
+
+ %1$s results for \"%2$s\"
+
+
+
diff --git a/src/src/Notes-master/res/values/styles.xml b/src/src/Notes-master/res/values/styles.xml
new file mode 100644
index 0000000..d750e65
--- /dev/null
+++ b/src/src/Notes-master/res/values/styles.xml
@@ -0,0 +1,69 @@
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
\ No newline at end of file
diff --git a/src/src/Notes-master/res/xml/preferences.xml b/src/src/Notes-master/res/xml/preferences.xml
new file mode 100644
index 0000000..fe58f8f
--- /dev/null
+++ b/src/src/Notes-master/res/xml/preferences.xml
@@ -0,0 +1,30 @@
+
+
+
+
+
+
+
+
+
+
+
+
diff --git a/src/src/Notes-master/res/xml/searchable.xml b/src/src/Notes-master/res/xml/searchable.xml
new file mode 100644
index 0000000..bf74f14
--- /dev/null
+++ b/src/src/Notes-master/res/xml/searchable.xml
@@ -0,0 +1,27 @@
+
+
+
+
+
diff --git a/src/src/Notes-master/res/xml/widget_2x_info.xml b/src/src/Notes-master/res/xml/widget_2x_info.xml
new file mode 100644
index 0000000..ac8b225
--- /dev/null
+++ b/src/src/Notes-master/res/xml/widget_2x_info.xml
@@ -0,0 +1,23 @@
+
+
+
+
+
+
diff --git a/src/src/Notes-master/res/xml/widget_4x_info.xml b/src/src/Notes-master/res/xml/widget_4x_info.xml
new file mode 100644
index 0000000..cf79f9c
--- /dev/null
+++ b/src/src/Notes-master/res/xml/widget_4x_info.xml
@@ -0,0 +1,23 @@
+
+
+
+
+
+
diff --git a/src/src/Notes-master/src/net/micode/notes/data/Contact.java b/src/src/Notes-master/src/net/micode/notes/data/Contact.java
new file mode 100644
index 0000000..d97ac5d
--- /dev/null
+++ b/src/src/Notes-master/src/net/micode/notes/data/Contact.java
@@ -0,0 +1,73 @@
+/*
+ * Copyright (c) 2010-2011, The MiCode Open Source Community (www.micode.net)
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+
+package net.micode.notes.data;
+
+import android.content.Context;
+import android.database.Cursor;
+import android.provider.ContactsContract.CommonDataKinds.Phone;
+import android.provider.ContactsContract.Data;
+import android.telephony.PhoneNumberUtils;
+import android.util.Log;
+
+import java.util.HashMap;
+
+public class Contact {
+ private static HashMap sContactCache;
+ private static final String TAG = "Contact";
+
+ private static final String CALLER_ID_SELECTION = "PHONE_NUMBERS_EQUAL(" + Phone.NUMBER
+ + ",?) AND " + Data.MIMETYPE + "='" + Phone.CONTENT_ITEM_TYPE + "'"
+ + " AND " + Data.RAW_CONTACT_ID + " IN "
+ + "(SELECT raw_contact_id "
+ + " FROM phone_lookup"
+ + " WHERE min_match = '+')";
+
+ public static String getContact(Context context, String phoneNumber) {
+ if(sContactCache == null) {
+ sContactCache = new HashMap();
+ }
+
+ if(sContactCache.containsKey(phoneNumber)) {
+ return sContactCache.get(phoneNumber);
+ }
+
+ String selection = CALLER_ID_SELECTION.replace("+",
+ PhoneNumberUtils.toCallerIDMinMatch(phoneNumber));
+ Cursor cursor = context.getContentResolver().query(
+ Data.CONTENT_URI,
+ new String [] { Phone.DISPLAY_NAME },
+ selection,
+ new String[] { phoneNumber },
+ null);
+
+ if (cursor != null && cursor.moveToFirst()) {
+ try {
+ String name = cursor.getString(0);
+ sContactCache.put(phoneNumber, name);
+ return name;
+ } catch (IndexOutOfBoundsException e) {
+ Log.e(TAG, " Cursor get string error " + e.toString());
+ return null;
+ } finally {
+ cursor.close();
+ }
+ } else {
+ Log.d(TAG, "No contact matched with number:" + phoneNumber);
+ return null;
+ }
+ }
+}
diff --git a/src/src/Notes-master/src/net/micode/notes/data/Notes.java b/src/src/Notes-master/src/net/micode/notes/data/Notes.java
new file mode 100644
index 0000000..f240604
--- /dev/null
+++ b/src/src/Notes-master/src/net/micode/notes/data/Notes.java
@@ -0,0 +1,279 @@
+/*
+ * Copyright (c) 2010-2011, The MiCode Open Source Community (www.micode.net)
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+
+package net.micode.notes.data;
+
+import android.net.Uri;
+public class Notes {
+ public static final String AUTHORITY = "micode_notes";
+ public static final String TAG = "Notes";
+ public static final int TYPE_NOTE = 0;
+ public static final int TYPE_FOLDER = 1;
+ public static final int TYPE_SYSTEM = 2;
+
+ /**
+ * Following IDs are system folders' identifiers
+ * {@link Notes#ID_ROOT_FOLDER } is default folder
+ * {@link Notes#ID_TEMPARAY_FOLDER } is for notes belonging no folder
+ * {@link Notes#ID_CALL_RECORD_FOLDER} is to store call records
+ */
+ public static final int ID_ROOT_FOLDER = 0;
+ public static final int ID_TEMPARAY_FOLDER = -1;
+ public static final int ID_CALL_RECORD_FOLDER = -2;
+ public static final int ID_TRASH_FOLER = -3;
+
+ public static final String INTENT_EXTRA_ALERT_DATE = "net.micode.notes.alert_date";
+ public static final String INTENT_EXTRA_BACKGROUND_ID = "net.micode.notes.background_color_id";
+ public static final String INTENT_EXTRA_WIDGET_ID = "net.micode.notes.widget_id";
+ public static final String INTENT_EXTRA_WIDGET_TYPE = "net.micode.notes.widget_type";
+ public static final String INTENT_EXTRA_FOLDER_ID = "net.micode.notes.folder_id";
+ public static final String INTENT_EXTRA_CALL_DATE = "net.micode.notes.call_date";
+
+ public static final int TYPE_WIDGET_INVALIDE = -1;
+ public static final int TYPE_WIDGET_2X = 0;
+ public static final int TYPE_WIDGET_4X = 1;
+
+ public static class DataConstants {
+ public static final String NOTE = TextNote.CONTENT_ITEM_TYPE;
+ public static final String CALL_NOTE = CallNote.CONTENT_ITEM_TYPE;
+ }
+
+ /**
+ * Uri to query all notes and folders
+ */
+ public static final Uri CONTENT_NOTE_URI = Uri.parse("content://" + AUTHORITY + "/note");
+
+ /**
+ * Uri to query data
+ */
+ public static final Uri CONTENT_DATA_URI = Uri.parse("content://" + AUTHORITY + "/data");
+
+ public interface NoteColumns {
+ /**
+ * The unique ID for a row
+ *
Type: INTEGER (long)
+ */
+ public static final String ID = "_id";
+
+ /**
+ * The parent's id for note or folder
+ *
Type: INTEGER (long)
+ */
+ public static final String PARENT_ID = "parent_id";
+
+ /**
+ * Created data for note or folder
+ *
Type: INTEGER (long)
+ */
+ public static final String CREATED_DATE = "created_date";
+
+ /**
+ * Latest modified date
+ *
Type: INTEGER (long)
+ */
+ public static final String MODIFIED_DATE = "modified_date";
+
+
+ /**
+ * Alert date
+ *
Type: INTEGER (long)
+ */
+ public static final String ALERTED_DATE = "alert_date";
+
+ /**
+ * Folder's name or text content of note
+ *
Type: TEXT
+ */
+ public static final String SNIPPET = "snippet";
+
+ /**
+ * Note's widget id
+ *
Type: INTEGER (long)
+ */
+ public static final String WIDGET_ID = "widget_id";
+
+ /**
+ * Note's widget type
+ *
Type: INTEGER (long)
+ */
+ public static final String WIDGET_TYPE = "widget_type";
+
+ /**
+ * Note's background color's id
+ *
Type: INTEGER (long)
+ */
+ public static final String BG_COLOR_ID = "bg_color_id";
+
+ /**
+ * For text note, it doesn't has attachment, for multi-media
+ * note, it has at least one attachment
+ *
Type: INTEGER
+ */
+ public static final String HAS_ATTACHMENT = "has_attachment";
+
+ /**
+ * Folder's count of notes
+ *
Type: INTEGER (long)
+ */
+ public static final String NOTES_COUNT = "notes_count";
+
+ /**
+ * The file type: folder or note
+ *
Type: INTEGER
+ */
+ public static final String TYPE = "type";
+
+ /**
+ * The last sync id
+ *
Type: INTEGER (long)
+ */
+ public static final String SYNC_ID = "sync_id";
+
+ /**
+ * Sign to indicate local modified or not
+ *
Type: INTEGER
+ */
+ public static final String LOCAL_MODIFIED = "local_modified";
+
+ /**
+ * Original parent id before moving into temporary folder
+ *
Type : INTEGER
+ */
+ public static final String ORIGIN_PARENT_ID = "origin_parent_id";
+
+ /**
+ * The gtask id
+ *
Type : TEXT
+ */
+ public static final String GTASK_ID = "gtask_id";
+
+ /**
+ * The version code
+ *
Type : INTEGER (long)
+ */
+ public static final String VERSION = "version";
+ }
+
+ public interface DataColumns {
+ /**
+ * The unique ID for a row
+ *
Type: INTEGER (long)
+ */
+ public static final String ID = "_id";
+
+ /**
+ * The MIME type of the item represented by this row.
+ *
Type: Text
+ */
+ public static final String MIME_TYPE = "mime_type";
+
+ /**
+ * The reference id to note that this data belongs to
+ *
Type: INTEGER (long)
+ */
+ public static final String NOTE_ID = "note_id";
+
+ /**
+ * Created data for note or folder
+ *
Type: INTEGER (long)
+ */
+ public static final String CREATED_DATE = "created_date";
+
+ /**
+ * Latest modified date
+ *
Type: INTEGER (long)
+ */
+ public static final String MODIFIED_DATE = "modified_date";
+
+ /**
+ * Data's content
+ *
Type: TEXT
+ */
+ public static final String CONTENT = "content";
+
+
+ /**
+ * Generic data column, the meaning is {@link #MIMETYPE} specific, used for
+ * integer data type
+ *
Type: INTEGER
+ */
+ public static final String DATA1 = "data1";
+
+ /**
+ * Generic data column, the meaning is {@link #MIMETYPE} specific, used for
+ * integer data type
+ *
Type: INTEGER
+ */
+ public static final String DATA2 = "data2";
+
+ /**
+ * Generic data column, the meaning is {@link #MIMETYPE} specific, used for
+ * TEXT data type
+ *
Type: TEXT
+ */
+ public static final String DATA3 = "data3";
+
+ /**
+ * Generic data column, the meaning is {@link #MIMETYPE} specific, used for
+ * TEXT data type
+ *
Type: TEXT
+ */
+ public static final String DATA4 = "data4";
+
+ /**
+ * Generic data column, the meaning is {@link #MIMETYPE} specific, used for
+ * TEXT data type
+ *
Type: TEXT
+ */
+ public static final String DATA5 = "data5";
+ }
+
+ public static final class TextNote implements DataColumns {
+ /**
+ * Mode to indicate the text in check list mode or not
+ *
Type: Integer 1:check list mode 0: normal mode
+ */
+ public static final String MODE = DATA1;
+
+ public static final int MODE_CHECK_LIST = 1;
+
+ public static final String CONTENT_TYPE = "vnd.android.cursor.dir/text_note";
+
+ public static final String CONTENT_ITEM_TYPE = "vnd.android.cursor.item/text_note";
+
+ public static final Uri CONTENT_URI = Uri.parse("content://" + AUTHORITY + "/text_note");
+ }
+
+ public static final class CallNote implements DataColumns {
+ /**
+ * Call date for this record
+ *
Type: INTEGER (long)
+ */
+ public static final String CALL_DATE = DATA1;
+
+ /**
+ * Phone number for this record
+ *
Type: TEXT
+ */
+ public static final String PHONE_NUMBER = DATA3;
+
+ public static final String CONTENT_TYPE = "vnd.android.cursor.dir/call_note";
+
+ public static final String CONTENT_ITEM_TYPE = "vnd.android.cursor.item/call_note";
+
+ public static final Uri CONTENT_URI = Uri.parse("content://" + AUTHORITY + "/call_note");
+ }
+}
diff --git a/src/src/Notes-master/src/net/micode/notes/data/NotesDatabaseHelper.java b/src/src/Notes-master/src/net/micode/notes/data/NotesDatabaseHelper.java
new file mode 100644
index 0000000..ffe5d57
--- /dev/null
+++ b/src/src/Notes-master/src/net/micode/notes/data/NotesDatabaseHelper.java
@@ -0,0 +1,362 @@
+/*
+ * Copyright (c) 2010-2011, The MiCode Open Source Community (www.micode.net)
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+
+package net.micode.notes.data;
+
+import android.content.ContentValues;
+import android.content.Context;
+import android.database.sqlite.SQLiteDatabase;
+import android.database.sqlite.SQLiteOpenHelper;
+import android.util.Log;
+
+import net.micode.notes.data.Notes.DataColumns;
+import net.micode.notes.data.Notes.DataConstants;
+import net.micode.notes.data.Notes.NoteColumns;
+
+
+public class NotesDatabaseHelper extends SQLiteOpenHelper {
+ private static final String DB_NAME = "note.db";
+
+ private static final int DB_VERSION = 4;
+
+ public interface TABLE {
+ public static final String NOTE = "note";
+
+ public static final String DATA = "data";
+ }
+
+ private static final String TAG = "NotesDatabaseHelper";
+
+ private static NotesDatabaseHelper mInstance;
+
+ private static final String CREATE_NOTE_TABLE_SQL =
+ "CREATE TABLE " + TABLE.NOTE + "(" +
+ NoteColumns.ID + " INTEGER PRIMARY KEY," +
+ NoteColumns.PARENT_ID + " INTEGER NOT NULL DEFAULT 0," +
+ NoteColumns.ALERTED_DATE + " INTEGER NOT NULL DEFAULT 0," +
+ NoteColumns.BG_COLOR_ID + " INTEGER NOT NULL DEFAULT 0," +
+ NoteColumns.CREATED_DATE + " INTEGER NOT NULL DEFAULT (strftime('%s','now') * 1000)," +
+ NoteColumns.HAS_ATTACHMENT + " INTEGER NOT NULL DEFAULT 0," +
+ NoteColumns.MODIFIED_DATE + " INTEGER NOT NULL DEFAULT (strftime('%s','now') * 1000)," +
+ NoteColumns.NOTES_COUNT + " INTEGER NOT NULL DEFAULT 0," +
+ NoteColumns.SNIPPET + " TEXT NOT NULL DEFAULT ''," +
+ NoteColumns.TYPE + " INTEGER NOT NULL DEFAULT 0," +
+ NoteColumns.WIDGET_ID + " INTEGER NOT NULL DEFAULT 0," +
+ NoteColumns.WIDGET_TYPE + " INTEGER NOT NULL DEFAULT -1," +
+ NoteColumns.SYNC_ID + " INTEGER NOT NULL DEFAULT 0," +
+ NoteColumns.LOCAL_MODIFIED + " INTEGER NOT NULL DEFAULT 0," +
+ NoteColumns.ORIGIN_PARENT_ID + " INTEGER NOT NULL DEFAULT 0," +
+ NoteColumns.GTASK_ID + " TEXT NOT NULL DEFAULT ''," +
+ NoteColumns.VERSION + " INTEGER NOT NULL DEFAULT 0" +
+ ")";
+
+ private static final String CREATE_DATA_TABLE_SQL =
+ "CREATE TABLE " + TABLE.DATA + "(" +
+ DataColumns.ID + " INTEGER PRIMARY KEY," +
+ DataColumns.MIME_TYPE + " TEXT NOT NULL," +
+ DataColumns.NOTE_ID + " INTEGER NOT NULL DEFAULT 0," +
+ NoteColumns.CREATED_DATE + " INTEGER NOT NULL DEFAULT (strftime('%s','now') * 1000)," +
+ NoteColumns.MODIFIED_DATE + " INTEGER NOT NULL DEFAULT (strftime('%s','now') * 1000)," +
+ DataColumns.CONTENT + " TEXT NOT NULL DEFAULT ''," +
+ DataColumns.DATA1 + " INTEGER," +
+ DataColumns.DATA2 + " INTEGER," +
+ DataColumns.DATA3 + " TEXT NOT NULL DEFAULT ''," +
+ DataColumns.DATA4 + " TEXT NOT NULL DEFAULT ''," +
+ DataColumns.DATA5 + " TEXT NOT NULL DEFAULT ''" +
+ ")";
+
+ private static final String CREATE_DATA_NOTE_ID_INDEX_SQL =
+ "CREATE INDEX IF NOT EXISTS note_id_index ON " +
+ TABLE.DATA + "(" + DataColumns.NOTE_ID + ");";
+
+ /**
+ * Increase folder's note count when move note to the folder
+ */
+ private static final String NOTE_INCREASE_FOLDER_COUNT_ON_UPDATE_TRIGGER =
+ "CREATE TRIGGER increase_folder_count_on_update "+
+ " AFTER UPDATE OF " + NoteColumns.PARENT_ID + " ON " + TABLE.NOTE +
+ " BEGIN " +
+ " UPDATE " + TABLE.NOTE +
+ " SET " + NoteColumns.NOTES_COUNT + "=" + NoteColumns.NOTES_COUNT + " + 1" +
+ " WHERE " + NoteColumns.ID + "=new." + NoteColumns.PARENT_ID + ";" +
+ " END";
+
+ /**
+ * Decrease folder's note count when move note from folder
+ */
+ private static final String NOTE_DECREASE_FOLDER_COUNT_ON_UPDATE_TRIGGER =
+ "CREATE TRIGGER decrease_folder_count_on_update " +
+ " AFTER UPDATE OF " + NoteColumns.PARENT_ID + " ON " + TABLE.NOTE +
+ " BEGIN " +
+ " UPDATE " + TABLE.NOTE +
+ " SET " + NoteColumns.NOTES_COUNT + "=" + NoteColumns.NOTES_COUNT + "-1" +
+ " WHERE " + NoteColumns.ID + "=old." + NoteColumns.PARENT_ID +
+ " AND " + NoteColumns.NOTES_COUNT + ">0" + ";" +
+ " END";
+
+ /**
+ * Increase folder's note count when insert new note to the folder
+ */
+ private static final String NOTE_INCREASE_FOLDER_COUNT_ON_INSERT_TRIGGER =
+ "CREATE TRIGGER increase_folder_count_on_insert " +
+ " AFTER INSERT ON " + TABLE.NOTE +
+ " BEGIN " +
+ " UPDATE " + TABLE.NOTE +
+ " SET " + NoteColumns.NOTES_COUNT + "=" + NoteColumns.NOTES_COUNT + " + 1" +
+ " WHERE " + NoteColumns.ID + "=new." + NoteColumns.PARENT_ID + ";" +
+ " END";
+
+ /**
+ * Decrease folder's note count when delete note from the folder
+ */
+ private static final String NOTE_DECREASE_FOLDER_COUNT_ON_DELETE_TRIGGER =
+ "CREATE TRIGGER decrease_folder_count_on_delete " +
+ " AFTER DELETE ON " + TABLE.NOTE +
+ " BEGIN " +
+ " UPDATE " + TABLE.NOTE +
+ " SET " + NoteColumns.NOTES_COUNT + "=" + NoteColumns.NOTES_COUNT + "-1" +
+ " WHERE " + NoteColumns.ID + "=old." + NoteColumns.PARENT_ID +
+ " AND " + NoteColumns.NOTES_COUNT + ">0;" +
+ " END";
+
+ /**
+ * Update note's content when insert data with type {@link DataConstants#NOTE}
+ */
+ private static final String DATA_UPDATE_NOTE_CONTENT_ON_INSERT_TRIGGER =
+ "CREATE TRIGGER update_note_content_on_insert " +
+ " AFTER INSERT ON " + TABLE.DATA +
+ " WHEN new." + DataColumns.MIME_TYPE + "='" + DataConstants.NOTE + "'" +
+ " BEGIN" +
+ " UPDATE " + TABLE.NOTE +
+ " SET " + NoteColumns.SNIPPET + "=new." + DataColumns.CONTENT +
+ " WHERE " + NoteColumns.ID + "=new." + DataColumns.NOTE_ID + ";" +
+ " END";
+
+ /**
+ * Update note's content when data with {@link DataConstants#NOTE} type has changed
+ */
+ private static final String DATA_UPDATE_NOTE_CONTENT_ON_UPDATE_TRIGGER =
+ "CREATE TRIGGER update_note_content_on_update " +
+ " AFTER UPDATE ON " + TABLE.DATA +
+ " WHEN old." + DataColumns.MIME_TYPE + "='" + DataConstants.NOTE + "'" +
+ " BEGIN" +
+ " UPDATE " + TABLE.NOTE +
+ " SET " + NoteColumns.SNIPPET + "=new." + DataColumns.CONTENT +
+ " WHERE " + NoteColumns.ID + "=new." + DataColumns.NOTE_ID + ";" +
+ " END";
+
+ /**
+ * Update note's content when data with {@link DataConstants#NOTE} type has deleted
+ */
+ private static final String DATA_UPDATE_NOTE_CONTENT_ON_DELETE_TRIGGER =
+ "CREATE TRIGGER update_note_content_on_delete " +
+ " AFTER delete ON " + TABLE.DATA +
+ " WHEN old." + DataColumns.MIME_TYPE + "='" + DataConstants.NOTE + "'" +
+ " BEGIN" +
+ " UPDATE " + TABLE.NOTE +
+ " SET " + NoteColumns.SNIPPET + "=''" +
+ " WHERE " + NoteColumns.ID + "=old." + DataColumns.NOTE_ID + ";" +
+ " END";
+
+ /**
+ * Delete datas belong to note which has been deleted
+ */
+ private static final String NOTE_DELETE_DATA_ON_DELETE_TRIGGER =
+ "CREATE TRIGGER delete_data_on_delete " +
+ " AFTER DELETE ON " + TABLE.NOTE +
+ " BEGIN" +
+ " DELETE FROM " + TABLE.DATA +
+ " WHERE " + DataColumns.NOTE_ID + "=old." + NoteColumns.ID + ";" +
+ " END";
+
+ /**
+ * Delete notes belong to folder which has been deleted
+ */
+ private static final String FOLDER_DELETE_NOTES_ON_DELETE_TRIGGER =
+ "CREATE TRIGGER folder_delete_notes_on_delete " +
+ " AFTER DELETE ON " + TABLE.NOTE +
+ " BEGIN" +
+ " DELETE FROM " + TABLE.NOTE +
+ " WHERE " + NoteColumns.PARENT_ID + "=old." + NoteColumns.ID + ";" +
+ " END";
+
+ /**
+ * Move notes belong to folder which has been moved to trash folder
+ */
+ private static final String FOLDER_MOVE_NOTES_ON_TRASH_TRIGGER =
+ "CREATE TRIGGER folder_move_notes_on_trash " +
+ " AFTER UPDATE ON " + TABLE.NOTE +
+ " WHEN new." + NoteColumns.PARENT_ID + "=" + Notes.ID_TRASH_FOLER +
+ " BEGIN" +
+ " UPDATE " + TABLE.NOTE +
+ " SET " + NoteColumns.PARENT_ID + "=" + Notes.ID_TRASH_FOLER +
+ " WHERE " + NoteColumns.PARENT_ID + "=old." + NoteColumns.ID + ";" +
+ " END";
+
+ public NotesDatabaseHelper(Context context) {
+ super(context, DB_NAME, null, DB_VERSION);
+ }
+
+ public void createNoteTable(SQLiteDatabase db) {
+ db.execSQL(CREATE_NOTE_TABLE_SQL);
+ reCreateNoteTableTriggers(db);
+ createSystemFolder(db);
+ Log.d(TAG, "note table has been created");
+ }
+
+ private void reCreateNoteTableTriggers(SQLiteDatabase db) {
+ db.execSQL("DROP TRIGGER IF EXISTS increase_folder_count_on_update");
+ db.execSQL("DROP TRIGGER IF EXISTS decrease_folder_count_on_update");
+ db.execSQL("DROP TRIGGER IF EXISTS decrease_folder_count_on_delete");
+ db.execSQL("DROP TRIGGER IF EXISTS delete_data_on_delete");
+ db.execSQL("DROP TRIGGER IF EXISTS increase_folder_count_on_insert");
+ db.execSQL("DROP TRIGGER IF EXISTS folder_delete_notes_on_delete");
+ db.execSQL("DROP TRIGGER IF EXISTS folder_move_notes_on_trash");
+
+ db.execSQL(NOTE_INCREASE_FOLDER_COUNT_ON_UPDATE_TRIGGER);
+ db.execSQL(NOTE_DECREASE_FOLDER_COUNT_ON_UPDATE_TRIGGER);
+ db.execSQL(NOTE_DECREASE_FOLDER_COUNT_ON_DELETE_TRIGGER);
+ db.execSQL(NOTE_DELETE_DATA_ON_DELETE_TRIGGER);
+ db.execSQL(NOTE_INCREASE_FOLDER_COUNT_ON_INSERT_TRIGGER);
+ db.execSQL(FOLDER_DELETE_NOTES_ON_DELETE_TRIGGER);
+ db.execSQL(FOLDER_MOVE_NOTES_ON_TRASH_TRIGGER);
+ }
+
+ private void createSystemFolder(SQLiteDatabase db) {
+ ContentValues values = new ContentValues();
+
+ /**
+ * call record foler for call notes
+ */
+ values.put(NoteColumns.ID, Notes.ID_CALL_RECORD_FOLDER);
+ values.put(NoteColumns.TYPE, Notes.TYPE_SYSTEM);
+ db.insert(TABLE.NOTE, null, values);
+
+ /**
+ * root folder which is default folder
+ */
+ values.clear();
+ values.put(NoteColumns.ID, Notes.ID_ROOT_FOLDER);
+ values.put(NoteColumns.TYPE, Notes.TYPE_SYSTEM);
+ db.insert(TABLE.NOTE, null, values);
+
+ /**
+ * temporary folder which is used for moving note
+ */
+ values.clear();
+ values.put(NoteColumns.ID, Notes.ID_TEMPARAY_FOLDER);
+ values.put(NoteColumns.TYPE, Notes.TYPE_SYSTEM);
+ db.insert(TABLE.NOTE, null, values);
+
+ /**
+ * create trash folder
+ */
+ values.clear();
+ values.put(NoteColumns.ID, Notes.ID_TRASH_FOLER);
+ values.put(NoteColumns.TYPE, Notes.TYPE_SYSTEM);
+ db.insert(TABLE.NOTE, null, values);
+ }
+
+ public void createDataTable(SQLiteDatabase db) {
+ db.execSQL(CREATE_DATA_TABLE_SQL);
+ reCreateDataTableTriggers(db);
+ db.execSQL(CREATE_DATA_NOTE_ID_INDEX_SQL);
+ Log.d(TAG, "data table has been created");
+ }
+
+ private void reCreateDataTableTriggers(SQLiteDatabase db) {
+ db.execSQL("DROP TRIGGER IF EXISTS update_note_content_on_insert");
+ db.execSQL("DROP TRIGGER IF EXISTS update_note_content_on_update");
+ db.execSQL("DROP TRIGGER IF EXISTS update_note_content_on_delete");
+
+ db.execSQL(DATA_UPDATE_NOTE_CONTENT_ON_INSERT_TRIGGER);
+ db.execSQL(DATA_UPDATE_NOTE_CONTENT_ON_UPDATE_TRIGGER);
+ db.execSQL(DATA_UPDATE_NOTE_CONTENT_ON_DELETE_TRIGGER);
+ }
+
+ static synchronized NotesDatabaseHelper getInstance(Context context) {
+ if (mInstance == null) {
+ mInstance = new NotesDatabaseHelper(context);
+ }
+ return mInstance;
+ }
+
+ @Override
+ public void onCreate(SQLiteDatabase db) {
+ createNoteTable(db);
+ createDataTable(db);
+ }
+
+ @Override
+ public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) {
+ boolean reCreateTriggers = false;
+ boolean skipV2 = false;
+
+ if (oldVersion == 1) {
+ upgradeToV2(db);
+ skipV2 = true; // this upgrade including the upgrade from v2 to v3
+ oldVersion++;
+ }
+
+ if (oldVersion == 2 && !skipV2) {
+ upgradeToV3(db);
+ reCreateTriggers = true;
+ oldVersion++;
+ }
+
+ if (oldVersion == 3) {
+ upgradeToV4(db);
+ oldVersion++;
+ }
+
+ if (reCreateTriggers) {
+ reCreateNoteTableTriggers(db);
+ reCreateDataTableTriggers(db);
+ }
+
+ if (oldVersion != newVersion) {
+ throw new IllegalStateException("Upgrade notes database to version " + newVersion
+ + "fails");
+ }
+ }
+
+ private void upgradeToV2(SQLiteDatabase db) {
+ db.execSQL("DROP TABLE IF EXISTS " + TABLE.NOTE);
+ db.execSQL("DROP TABLE IF EXISTS " + TABLE.DATA);
+ createNoteTable(db);
+ createDataTable(db);
+ }
+
+ private void upgradeToV3(SQLiteDatabase db) {
+ // drop unused triggers
+ db.execSQL("DROP TRIGGER IF EXISTS update_note_modified_date_on_insert");
+ db.execSQL("DROP TRIGGER IF EXISTS update_note_modified_date_on_delete");
+ db.execSQL("DROP TRIGGER IF EXISTS update_note_modified_date_on_update");
+ // add a column for gtask id
+ db.execSQL("ALTER TABLE " + TABLE.NOTE + " ADD COLUMN " + NoteColumns.GTASK_ID
+ + " TEXT NOT NULL DEFAULT ''");
+ // add a trash system folder
+ ContentValues values = new ContentValues();
+ values.put(NoteColumns.ID, Notes.ID_TRASH_FOLER);
+ values.put(NoteColumns.TYPE, Notes.TYPE_SYSTEM);
+ db.insert(TABLE.NOTE, null, values);
+ }
+
+ private void upgradeToV4(SQLiteDatabase db) {
+ db.execSQL("ALTER TABLE " + TABLE.NOTE + " ADD COLUMN " + NoteColumns.VERSION
+ + " INTEGER NOT NULL DEFAULT 0");
+ }
+}
diff --git a/src/src/Notes-master/src/net/micode/notes/data/NotesProvider.java b/src/src/Notes-master/src/net/micode/notes/data/NotesProvider.java
new file mode 100644
index 0000000..edb0a60
--- /dev/null
+++ b/src/src/Notes-master/src/net/micode/notes/data/NotesProvider.java
@@ -0,0 +1,305 @@
+/*
+ * Copyright (c) 2010-2011, The MiCode Open Source Community (www.micode.net)
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+
+package net.micode.notes.data;
+
+
+import android.app.SearchManager;
+import android.content.ContentProvider;
+import android.content.ContentUris;
+import android.content.ContentValues;
+import android.content.Intent;
+import android.content.UriMatcher;
+import android.database.Cursor;
+import android.database.sqlite.SQLiteDatabase;
+import android.net.Uri;
+import android.text.TextUtils;
+import android.util.Log;
+
+import net.micode.notes.R;
+import net.micode.notes.data.Notes.DataColumns;
+import net.micode.notes.data.Notes.NoteColumns;
+import net.micode.notes.data.NotesDatabaseHelper.TABLE;
+
+
+public class NotesProvider extends ContentProvider {
+ private static final UriMatcher mMatcher;
+
+ private NotesDatabaseHelper mHelper;
+
+ private static final String TAG = "NotesProvider";
+
+ private static final int URI_NOTE = 1;
+ private static final int URI_NOTE_ITEM = 2;
+ private static final int URI_DATA = 3;
+ private static final int URI_DATA_ITEM = 4;
+
+ private static final int URI_SEARCH = 5;
+ private static final int URI_SEARCH_SUGGEST = 6;
+
+ static {
+ mMatcher = new UriMatcher(UriMatcher.NO_MATCH);
+ mMatcher.addURI(Notes.AUTHORITY, "note", URI_NOTE);
+ mMatcher.addURI(Notes.AUTHORITY, "note/#", URI_NOTE_ITEM);
+ mMatcher.addURI(Notes.AUTHORITY, "data", URI_DATA);
+ mMatcher.addURI(Notes.AUTHORITY, "data/#", URI_DATA_ITEM);
+ mMatcher.addURI(Notes.AUTHORITY, "search", URI_SEARCH);
+ mMatcher.addURI(Notes.AUTHORITY, SearchManager.SUGGEST_URI_PATH_QUERY, URI_SEARCH_SUGGEST);
+ mMatcher.addURI(Notes.AUTHORITY, SearchManager.SUGGEST_URI_PATH_QUERY + "/*", URI_SEARCH_SUGGEST);
+ }
+
+ /**
+ * x'0A' represents the '\n' character in sqlite. For title and content in the search result,
+ * we will trim '\n' and white space in order to show more information.
+ */
+ private static final String NOTES_SEARCH_PROJECTION = NoteColumns.ID + ","
+ + NoteColumns.ID + " AS " + SearchManager.SUGGEST_COLUMN_INTENT_EXTRA_DATA + ","
+ + "TRIM(REPLACE(" + NoteColumns.SNIPPET + ", x'0A','')) AS " + SearchManager.SUGGEST_COLUMN_TEXT_1 + ","
+ + "TRIM(REPLACE(" + NoteColumns.SNIPPET + ", x'0A','')) AS " + SearchManager.SUGGEST_COLUMN_TEXT_2 + ","
+ + R.drawable.search_result + " AS " + SearchManager.SUGGEST_COLUMN_ICON_1 + ","
+ + "'" + Intent.ACTION_VIEW + "' AS " + SearchManager.SUGGEST_COLUMN_INTENT_ACTION + ","
+ + "'" + Notes.TextNote.CONTENT_TYPE + "' AS " + SearchManager.SUGGEST_COLUMN_INTENT_DATA;
+
+ private static String NOTES_SNIPPET_SEARCH_QUERY = "SELECT " + NOTES_SEARCH_PROJECTION
+ + " FROM " + TABLE.NOTE
+ + " WHERE " + NoteColumns.SNIPPET + " LIKE ?"
+ + " AND " + NoteColumns.PARENT_ID + "<>" + Notes.ID_TRASH_FOLER
+ + " AND " + NoteColumns.TYPE + "=" + Notes.TYPE_NOTE;
+
+ @Override
+ public boolean onCreate() {
+ mHelper = NotesDatabaseHelper.getInstance(getContext());
+ return true;
+ }
+
+ @Override
+ public Cursor query(Uri uri, String[] projection, String selection, String[] selectionArgs,
+ String sortOrder) {
+ Cursor c = null;
+ SQLiteDatabase db = mHelper.getReadableDatabase();
+ String id = null;
+ switch (mMatcher.match(uri)) {
+ case URI_NOTE:
+ c = db.query(TABLE.NOTE, projection, selection, selectionArgs, null, null,
+ sortOrder);
+ break;
+ case URI_NOTE_ITEM:
+ id = uri.getPathSegments().get(1);
+ c = db.query(TABLE.NOTE, projection, NoteColumns.ID + "=" + id
+ + parseSelection(selection), selectionArgs, null, null, sortOrder);
+ break;
+ case URI_DATA:
+ c = db.query(TABLE.DATA, projection, selection, selectionArgs, null, null,
+ sortOrder);
+ break;
+ case URI_DATA_ITEM:
+ id = uri.getPathSegments().get(1);
+ c = db.query(TABLE.DATA, projection, DataColumns.ID + "=" + id
+ + parseSelection(selection), selectionArgs, null, null, sortOrder);
+ break;
+ case URI_SEARCH:
+ case URI_SEARCH_SUGGEST:
+ if (sortOrder != null || projection != null) {
+ throw new IllegalArgumentException(
+ "do not specify sortOrder, selection, selectionArgs, or projection" + "with this query");
+ }
+
+ String searchString = null;
+ if (mMatcher.match(uri) == URI_SEARCH_SUGGEST) {
+ if (uri.getPathSegments().size() > 1) {
+ searchString = uri.getPathSegments().get(1);
+ }
+ } else {
+ searchString = uri.getQueryParameter("pattern");
+ }
+
+ if (TextUtils.isEmpty(searchString)) {
+ return null;
+ }
+
+ try {
+ searchString = String.format("%%%s%%", searchString);
+ c = db.rawQuery(NOTES_SNIPPET_SEARCH_QUERY,
+ new String[] { searchString });
+ } catch (IllegalStateException ex) {
+ Log.e(TAG, "got exception: " + ex.toString());
+ }
+ break;
+ default:
+ throw new IllegalArgumentException("Unknown URI " + uri);
+ }
+ if (c != null) {
+ c.setNotificationUri(getContext().getContentResolver(), uri);
+ }
+ return c;
+ }
+
+ @Override
+ public Uri insert(Uri uri, ContentValues values) {
+ SQLiteDatabase db = mHelper.getWritableDatabase();
+ long dataId = 0, noteId = 0, insertedId = 0;
+ switch (mMatcher.match(uri)) {
+ case URI_NOTE:
+ insertedId = noteId = db.insert(TABLE.NOTE, null, values);
+ break;
+ case URI_DATA:
+ if (values.containsKey(DataColumns.NOTE_ID)) {
+ noteId = values.getAsLong(DataColumns.NOTE_ID);
+ } else {
+ Log.d(TAG, "Wrong data format without note id:" + values.toString());
+ }
+ insertedId = dataId = db.insert(TABLE.DATA, null, values);
+ break;
+ default:
+ throw new IllegalArgumentException("Unknown URI " + uri);
+ }
+ // Notify the note uri
+ if (noteId > 0) {
+ getContext().getContentResolver().notifyChange(
+ ContentUris.withAppendedId(Notes.CONTENT_NOTE_URI, noteId), null);
+ }
+
+ // Notify the data uri
+ if (dataId > 0) {
+ getContext().getContentResolver().notifyChange(
+ ContentUris.withAppendedId(Notes.CONTENT_DATA_URI, dataId), null);
+ }
+
+ return ContentUris.withAppendedId(uri, insertedId);
+ }
+
+ @Override
+ public int delete(Uri uri, String selection, String[] selectionArgs) {
+ int count = 0;
+ String id = null;
+ SQLiteDatabase db = mHelper.getWritableDatabase();
+ boolean deleteData = false;
+ switch (mMatcher.match(uri)) {
+ case URI_NOTE:
+ selection = "(" + selection + ") AND " + NoteColumns.ID + ">0 ";
+ count = db.delete(TABLE.NOTE, selection, selectionArgs);
+ break;
+ case URI_NOTE_ITEM:
+ id = uri.getPathSegments().get(1);
+ /**
+ * ID that smaller than 0 is system folder which is not allowed to
+ * trash
+ */
+ long noteId = Long.valueOf(id);
+ if (noteId <= 0) {
+ break;
+ }
+ count = db.delete(TABLE.NOTE,
+ NoteColumns.ID + "=" + id + parseSelection(selection), selectionArgs);
+ break;
+ case URI_DATA:
+ count = db.delete(TABLE.DATA, selection, selectionArgs);
+ deleteData = true;
+ break;
+ case URI_DATA_ITEM:
+ id = uri.getPathSegments().get(1);
+ count = db.delete(TABLE.DATA,
+ DataColumns.ID + "=" + id + parseSelection(selection), selectionArgs);
+ deleteData = true;
+ break;
+ default:
+ throw new IllegalArgumentException("Unknown URI " + uri);
+ }
+ if (count > 0) {
+ if (deleteData) {
+ getContext().getContentResolver().notifyChange(Notes.CONTENT_NOTE_URI, null);
+ }
+ getContext().getContentResolver().notifyChange(uri, null);
+ }
+ return count;
+ }
+
+ @Override
+ public int update(Uri uri, ContentValues values, String selection, String[] selectionArgs) {
+ int count = 0;
+ String id = null;
+ SQLiteDatabase db = mHelper.getWritableDatabase();
+ boolean updateData = false;
+ switch (mMatcher.match(uri)) {
+ case URI_NOTE:
+ increaseNoteVersion(-1, selection, selectionArgs);
+ count = db.update(TABLE.NOTE, values, selection, selectionArgs);
+ break;
+ case URI_NOTE_ITEM:
+ id = uri.getPathSegments().get(1);
+ increaseNoteVersion(Long.valueOf(id), selection, selectionArgs);
+ count = db.update(TABLE.NOTE, values, NoteColumns.ID + "=" + id
+ + parseSelection(selection), selectionArgs);
+ break;
+ case URI_DATA:
+ count = db.update(TABLE.DATA, values, selection, selectionArgs);
+ updateData = true;
+ break;
+ case URI_DATA_ITEM:
+ id = uri.getPathSegments().get(1);
+ count = db.update(TABLE.DATA, values, DataColumns.ID + "=" + id
+ + parseSelection(selection), selectionArgs);
+ updateData = true;
+ break;
+ default:
+ throw new IllegalArgumentException("Unknown URI " + uri);
+ }
+
+ if (count > 0) {
+ if (updateData) {
+ getContext().getContentResolver().notifyChange(Notes.CONTENT_NOTE_URI, null);
+ }
+ getContext().getContentResolver().notifyChange(uri, null);
+ }
+ return count;
+ }
+
+ private String parseSelection(String selection) {
+ return (!TextUtils.isEmpty(selection) ? " AND (" + selection + ')' : "");
+ }
+
+ private void increaseNoteVersion(long id, String selection, String[] selectionArgs) {
+ StringBuilder sql = new StringBuilder(120);
+ sql.append("UPDATE ");
+ sql.append(TABLE.NOTE);
+ sql.append(" SET ");
+ sql.append(NoteColumns.VERSION);
+ sql.append("=" + NoteColumns.VERSION + "+1 ");
+
+ if (id > 0 || !TextUtils.isEmpty(selection)) {
+ sql.append(" WHERE ");
+ }
+ if (id > 0) {
+ sql.append(NoteColumns.ID + "=" + String.valueOf(id));
+ }
+ if (!TextUtils.isEmpty(selection)) {
+ String selectString = id > 0 ? parseSelection(selection) : selection;
+ for (String args : selectionArgs) {
+ selectString = selectString.replaceFirst("\\?", args);
+ }
+ sql.append(selectString);
+ }
+
+ mHelper.getWritableDatabase().execSQL(sql.toString());
+ }
+
+ @Override
+ public String getType(Uri uri) {
+ // TODO Auto-generated method stub
+ return null;
+ }
+
+}
diff --git a/src/src/Notes-master/src/net/micode/notes/gtask/data/MetaData.java b/src/src/Notes-master/src/net/micode/notes/gtask/data/MetaData.java
new file mode 100644
index 0000000..3a2050b
--- /dev/null
+++ b/src/src/Notes-master/src/net/micode/notes/gtask/data/MetaData.java
@@ -0,0 +1,82 @@
+/*
+ * Copyright (c) 2010-2011, The MiCode Open Source Community (www.micode.net)
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+
+package net.micode.notes.gtask.data;
+
+import android.database.Cursor;
+import android.util.Log;
+
+import net.micode.notes.tool.GTaskStringUtils;
+
+import org.json.JSONException;
+import org.json.JSONObject;
+
+
+public class MetaData extends Task {
+ private final static String TAG = MetaData.class.getSimpleName();
+
+ private String mRelatedGid = null;
+
+ public void setMeta(String gid, JSONObject metaInfo) {
+ try {
+ metaInfo.put(GTaskStringUtils.META_HEAD_GTASK_ID, gid);
+ } catch (JSONException e) {
+ Log.e(TAG, "failed to put related gid");
+ }
+ setNotes(metaInfo.toString());
+ setName(GTaskStringUtils.META_NOTE_NAME);
+ }
+
+ public String getRelatedGid() {
+ return mRelatedGid;
+ }
+
+ @Override
+ public boolean isWorthSaving() {
+ return getNotes() != null;
+ }
+
+ @Override
+ public void setContentByRemoteJSON(JSONObject js) {
+ super.setContentByRemoteJSON(js);
+ if (getNotes() != null) {
+ try {
+ JSONObject metaInfo = new JSONObject(getNotes().trim());
+ mRelatedGid = metaInfo.getString(GTaskStringUtils.META_HEAD_GTASK_ID);
+ } catch (JSONException e) {
+ Log.w(TAG, "failed to get related gid");
+ mRelatedGid = null;
+ }
+ }
+ }
+
+ @Override
+ public void setContentByLocalJSON(JSONObject js) {
+ // this function should not be called
+ throw new IllegalAccessError("MetaData:setContentByLocalJSON should not be called");
+ }
+
+ @Override
+ public JSONObject getLocalJSONFromContent() {
+ throw new IllegalAccessError("MetaData:getLocalJSONFromContent should not be called");
+ }
+
+ @Override
+ public int getSyncAction(Cursor c) {
+ throw new IllegalAccessError("MetaData:getSyncAction should not be called");
+ }
+
+}
diff --git a/src/src/Notes-master/src/net/micode/notes/gtask/data/Node.java b/src/src/Notes-master/src/net/micode/notes/gtask/data/Node.java
new file mode 100644
index 0000000..63950e0
--- /dev/null
+++ b/src/src/Notes-master/src/net/micode/notes/gtask/data/Node.java
@@ -0,0 +1,101 @@
+/*
+ * Copyright (c) 2010-2011, The MiCode Open Source Community (www.micode.net)
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+
+package net.micode.notes.gtask.data;
+
+import android.database.Cursor;
+
+import org.json.JSONObject;
+
+public abstract class Node {
+ public static final int SYNC_ACTION_NONE = 0;
+
+ public static final int SYNC_ACTION_ADD_REMOTE = 1;
+
+ public static final int SYNC_ACTION_ADD_LOCAL = 2;
+
+ public static final int SYNC_ACTION_DEL_REMOTE = 3;
+
+ public static final int SYNC_ACTION_DEL_LOCAL = 4;
+
+ public static final int SYNC_ACTION_UPDATE_REMOTE = 5;
+
+ public static final int SYNC_ACTION_UPDATE_LOCAL = 6;
+
+ public static final int SYNC_ACTION_UPDATE_CONFLICT = 7;
+
+ public static final int SYNC_ACTION_ERROR = 8;
+
+ private String mGid;
+
+ private String mName;
+
+ private long mLastModified;
+
+ private boolean mDeleted;
+
+ public Node() {
+ mGid = null;
+ mName = "";
+ mLastModified = 0;
+ mDeleted = false;
+ }
+
+ public abstract JSONObject getCreateAction(int actionId);
+
+ public abstract JSONObject getUpdateAction(int actionId);
+
+ public abstract void setContentByRemoteJSON(JSONObject js);
+
+ public abstract void setContentByLocalJSON(JSONObject js);
+
+ public abstract JSONObject getLocalJSONFromContent();
+
+ public abstract int getSyncAction(Cursor c);
+
+ public void setGid(String gid) {
+ this.mGid = gid;
+ }
+
+ public void setName(String name) {
+ this.mName = name;
+ }
+
+ public void setLastModified(long lastModified) {
+ this.mLastModified = lastModified;
+ }
+
+ public void setDeleted(boolean deleted) {
+ this.mDeleted = deleted;
+ }
+
+ public String getGid() {
+ return this.mGid;
+ }
+
+ public String getName() {
+ return this.mName;
+ }
+
+ public long getLastModified() {
+ return this.mLastModified;
+ }
+
+ public boolean getDeleted() {
+ return this.mDeleted;
+ }
+
+}
diff --git a/src/src/Notes-master/src/net/micode/notes/gtask/data/SqlData.java b/src/src/Notes-master/src/net/micode/notes/gtask/data/SqlData.java
new file mode 100644
index 0000000..d3ec3be
--- /dev/null
+++ b/src/src/Notes-master/src/net/micode/notes/gtask/data/SqlData.java
@@ -0,0 +1,189 @@
+/*
+ * Copyright (c) 2010-2011, The MiCode Open Source Community (www.micode.net)
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+
+package net.micode.notes.gtask.data;
+
+import android.content.ContentResolver;
+import android.content.ContentUris;
+import android.content.ContentValues;
+import android.content.Context;
+import android.database.Cursor;
+import android.net.Uri;
+import android.util.Log;
+
+import net.micode.notes.data.Notes;
+import net.micode.notes.data.Notes.DataColumns;
+import net.micode.notes.data.Notes.DataConstants;
+import net.micode.notes.data.Notes.NoteColumns;
+import net.micode.notes.data.NotesDatabaseHelper.TABLE;
+import net.micode.notes.gtask.exception.ActionFailureException;
+
+import org.json.JSONException;
+import org.json.JSONObject;
+
+
+public class SqlData {
+ private static final String TAG = SqlData.class.getSimpleName();
+
+ private static final int INVALID_ID = -99999;
+
+ public static final String[] PROJECTION_DATA = new String[] {
+ DataColumns.ID, DataColumns.MIME_TYPE, DataColumns.CONTENT, DataColumns.DATA1,
+ DataColumns.DATA3
+ };
+
+ public static final int DATA_ID_COLUMN = 0;
+
+ public static final int DATA_MIME_TYPE_COLUMN = 1;
+
+ public static final int DATA_CONTENT_COLUMN = 2;
+
+ public static final int DATA_CONTENT_DATA_1_COLUMN = 3;
+
+ public static final int DATA_CONTENT_DATA_3_COLUMN = 4;
+
+ private ContentResolver mContentResolver;
+
+ private boolean mIsCreate;
+
+ private long mDataId;
+
+ private String mDataMimeType;
+
+ private String mDataContent;
+
+ private long mDataContentData1;
+
+ private String mDataContentData3;
+
+ private ContentValues mDiffDataValues;
+
+ public SqlData(Context context) {
+ mContentResolver = context.getContentResolver();
+ mIsCreate = true;
+ mDataId = INVALID_ID;
+ mDataMimeType = DataConstants.NOTE;
+ mDataContent = "";
+ mDataContentData1 = 0;
+ mDataContentData3 = "";
+ mDiffDataValues = new ContentValues();
+ }
+
+ public SqlData(Context context, Cursor c) {
+ mContentResolver = context.getContentResolver();
+ mIsCreate = false;
+ loadFromCursor(c);
+ mDiffDataValues = new ContentValues();
+ }
+
+ private void loadFromCursor(Cursor c) {
+ mDataId = c.getLong(DATA_ID_COLUMN);
+ mDataMimeType = c.getString(DATA_MIME_TYPE_COLUMN);
+ mDataContent = c.getString(DATA_CONTENT_COLUMN);
+ mDataContentData1 = c.getLong(DATA_CONTENT_DATA_1_COLUMN);
+ mDataContentData3 = c.getString(DATA_CONTENT_DATA_3_COLUMN);
+ }
+
+ public void setContent(JSONObject js) throws JSONException {
+ long dataId = js.has(DataColumns.ID) ? js.getLong(DataColumns.ID) : INVALID_ID;
+ if (mIsCreate || mDataId != dataId) {
+ mDiffDataValues.put(DataColumns.ID, dataId);
+ }
+ mDataId = dataId;
+
+ String dataMimeType = js.has(DataColumns.MIME_TYPE) ? js.getString(DataColumns.MIME_TYPE)
+ : DataConstants.NOTE;
+ if (mIsCreate || !mDataMimeType.equals(dataMimeType)) {
+ mDiffDataValues.put(DataColumns.MIME_TYPE, dataMimeType);
+ }
+ mDataMimeType = dataMimeType;
+
+ String dataContent = js.has(DataColumns.CONTENT) ? js.getString(DataColumns.CONTENT) : "";
+ if (mIsCreate || !mDataContent.equals(dataContent)) {
+ mDiffDataValues.put(DataColumns.CONTENT, dataContent);
+ }
+ mDataContent = dataContent;
+
+ long dataContentData1 = js.has(DataColumns.DATA1) ? js.getLong(DataColumns.DATA1) : 0;
+ if (mIsCreate || mDataContentData1 != dataContentData1) {
+ mDiffDataValues.put(DataColumns.DATA1, dataContentData1);
+ }
+ mDataContentData1 = dataContentData1;
+
+ String dataContentData3 = js.has(DataColumns.DATA3) ? js.getString(DataColumns.DATA3) : "";
+ if (mIsCreate || !mDataContentData3.equals(dataContentData3)) {
+ mDiffDataValues.put(DataColumns.DATA3, dataContentData3);
+ }
+ mDataContentData3 = dataContentData3;
+ }
+
+ public JSONObject getContent() throws JSONException {
+ if (mIsCreate) {
+ Log.e(TAG, "it seems that we haven't created this in database yet");
+ return null;
+ }
+ JSONObject js = new JSONObject();
+ js.put(DataColumns.ID, mDataId);
+ js.put(DataColumns.MIME_TYPE, mDataMimeType);
+ js.put(DataColumns.CONTENT, mDataContent);
+ js.put(DataColumns.DATA1, mDataContentData1);
+ js.put(DataColumns.DATA3, mDataContentData3);
+ return js;
+ }
+
+ public void commit(long noteId, boolean validateVersion, long version) {
+
+ if (mIsCreate) {
+ if (mDataId == INVALID_ID && mDiffDataValues.containsKey(DataColumns.ID)) {
+ mDiffDataValues.remove(DataColumns.ID);
+ }
+
+ mDiffDataValues.put(DataColumns.NOTE_ID, noteId);
+ Uri uri = mContentResolver.insert(Notes.CONTENT_DATA_URI, mDiffDataValues);
+ try {
+ mDataId = Long.valueOf(uri.getPathSegments().get(1));
+ } catch (NumberFormatException e) {
+ Log.e(TAG, "Get note id error :" + e.toString());
+ throw new ActionFailureException("create note failed");
+ }
+ } else {
+ if (mDiffDataValues.size() > 0) {
+ int result = 0;
+ if (!validateVersion) {
+ result = mContentResolver.update(ContentUris.withAppendedId(
+ Notes.CONTENT_DATA_URI, mDataId), mDiffDataValues, null, null);
+ } else {
+ result = mContentResolver.update(ContentUris.withAppendedId(
+ Notes.CONTENT_DATA_URI, mDataId), mDiffDataValues,
+ " ? in (SELECT " + NoteColumns.ID + " FROM " + TABLE.NOTE
+ + " WHERE " + NoteColumns.VERSION + "=?)", new String[] {
+ String.valueOf(noteId), String.valueOf(version)
+ });
+ }
+ if (result == 0) {
+ Log.w(TAG, "there is no update. maybe user updates note when syncing");
+ }
+ }
+ }
+
+ mDiffDataValues.clear();
+ mIsCreate = false;
+ }
+
+ public long getId() {
+ return mDataId;
+ }
+}
diff --git a/src/src/Notes-master/src/net/micode/notes/gtask/data/SqlNote.java b/src/src/Notes-master/src/net/micode/notes/gtask/data/SqlNote.java
new file mode 100644
index 0000000..79a4095
--- /dev/null
+++ b/src/src/Notes-master/src/net/micode/notes/gtask/data/SqlNote.java
@@ -0,0 +1,505 @@
+/*
+ * Copyright (c) 2010-2011, The MiCode Open Source Community (www.micode.net)
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+
+package net.micode.notes.gtask.data;
+
+import android.appwidget.AppWidgetManager;
+import android.content.ContentResolver;
+import android.content.ContentValues;
+import android.content.Context;
+import android.database.Cursor;
+import android.net.Uri;
+import android.util.Log;
+
+import net.micode.notes.data.Notes;
+import net.micode.notes.data.Notes.DataColumns;
+import net.micode.notes.data.Notes.NoteColumns;
+import net.micode.notes.gtask.exception.ActionFailureException;
+import net.micode.notes.tool.GTaskStringUtils;
+import net.micode.notes.tool.ResourceParser;
+
+import org.json.JSONArray;
+import org.json.JSONException;
+import org.json.JSONObject;
+
+import java.util.ArrayList;
+
+
+public class SqlNote {
+ private static final String TAG = SqlNote.class.getSimpleName();
+
+ private static final int INVALID_ID = -99999;
+
+ public static final String[] PROJECTION_NOTE = new String[] {
+ NoteColumns.ID, NoteColumns.ALERTED_DATE, NoteColumns.BG_COLOR_ID,
+ NoteColumns.CREATED_DATE, NoteColumns.HAS_ATTACHMENT, NoteColumns.MODIFIED_DATE,
+ NoteColumns.NOTES_COUNT, NoteColumns.PARENT_ID, NoteColumns.SNIPPET, NoteColumns.TYPE,
+ NoteColumns.WIDGET_ID, NoteColumns.WIDGET_TYPE, NoteColumns.SYNC_ID,
+ NoteColumns.LOCAL_MODIFIED, NoteColumns.ORIGIN_PARENT_ID, NoteColumns.GTASK_ID,
+ NoteColumns.VERSION
+ };
+
+ public static final int ID_COLUMN = 0;
+
+ public static final int ALERTED_DATE_COLUMN = 1;
+
+ public static final int BG_COLOR_ID_COLUMN = 2;
+
+ public static final int CREATED_DATE_COLUMN = 3;
+
+ public static final int HAS_ATTACHMENT_COLUMN = 4;
+
+ public static final int MODIFIED_DATE_COLUMN = 5;
+
+ public static final int NOTES_COUNT_COLUMN = 6;
+
+ public static final int PARENT_ID_COLUMN = 7;
+
+ public static final int SNIPPET_COLUMN = 8;
+
+ public static final int TYPE_COLUMN = 9;
+
+ public static final int WIDGET_ID_COLUMN = 10;
+
+ public static final int WIDGET_TYPE_COLUMN = 11;
+
+ public static final int SYNC_ID_COLUMN = 12;
+
+ public static final int LOCAL_MODIFIED_COLUMN = 13;
+
+ public static final int ORIGIN_PARENT_ID_COLUMN = 14;
+
+ public static final int GTASK_ID_COLUMN = 15;
+
+ public static final int VERSION_COLUMN = 16;
+
+ private Context mContext;
+
+ private ContentResolver mContentResolver;
+
+ private boolean mIsCreate;
+
+ private long mId;
+
+ private long mAlertDate;
+
+ private int mBgColorId;
+
+ private long mCreatedDate;
+
+ private int mHasAttachment;
+
+ private long mModifiedDate;
+
+ private long mParentId;
+
+ private String mSnippet;
+
+ private int mType;
+
+ private int mWidgetId;
+
+ private int mWidgetType;
+
+ private long mOriginParent;
+
+ private long mVersion;
+
+ private ContentValues mDiffNoteValues;
+
+ private ArrayList mDataList;
+
+ public SqlNote(Context context) {
+ mContext = context;
+ mContentResolver = context.getContentResolver();
+ mIsCreate = true;
+ mId = INVALID_ID;
+ mAlertDate = 0;
+ mBgColorId = ResourceParser.getDefaultBgId(context);
+ mCreatedDate = System.currentTimeMillis();
+ mHasAttachment = 0;
+ mModifiedDate = System.currentTimeMillis();
+ mParentId = 0;
+ mSnippet = "";
+ mType = Notes.TYPE_NOTE;
+ mWidgetId = AppWidgetManager.INVALID_APPWIDGET_ID;
+ mWidgetType = Notes.TYPE_WIDGET_INVALIDE;
+ mOriginParent = 0;
+ mVersion = 0;
+ mDiffNoteValues = new ContentValues();
+ mDataList = new ArrayList();
+ }
+
+ public SqlNote(Context context, Cursor c) {
+ mContext = context;
+ mContentResolver = context.getContentResolver();
+ mIsCreate = false;
+ loadFromCursor(c);
+ mDataList = new ArrayList();
+ if (mType == Notes.TYPE_NOTE)
+ loadDataContent();
+ mDiffNoteValues = new ContentValues();
+ }
+
+ public SqlNote(Context context, long id) {
+ mContext = context;
+ mContentResolver = context.getContentResolver();
+ mIsCreate = false;
+ loadFromCursor(id);
+ mDataList = new ArrayList();
+ if (mType == Notes.TYPE_NOTE)
+ loadDataContent();
+ mDiffNoteValues = new ContentValues();
+
+ }
+
+ private void loadFromCursor(long id) {
+ Cursor c = null;
+ try {
+ c = mContentResolver.query(Notes.CONTENT_NOTE_URI, PROJECTION_NOTE, "(_id=?)",
+ new String[] {
+ String.valueOf(id)
+ }, null);
+ if (c != null) {
+ c.moveToNext();
+ loadFromCursor(c);
+ } else {
+ Log.w(TAG, "loadFromCursor: cursor = null");
+ }
+ } finally {
+ if (c != null)
+ c.close();
+ }
+ }
+
+ private void loadFromCursor(Cursor c) {
+ mId = c.getLong(ID_COLUMN);
+ mAlertDate = c.getLong(ALERTED_DATE_COLUMN);
+ mBgColorId = c.getInt(BG_COLOR_ID_COLUMN);
+ mCreatedDate = c.getLong(CREATED_DATE_COLUMN);
+ mHasAttachment = c.getInt(HAS_ATTACHMENT_COLUMN);
+ mModifiedDate = c.getLong(MODIFIED_DATE_COLUMN);
+ mParentId = c.getLong(PARENT_ID_COLUMN);
+ mSnippet = c.getString(SNIPPET_COLUMN);
+ mType = c.getInt(TYPE_COLUMN);
+ mWidgetId = c.getInt(WIDGET_ID_COLUMN);
+ mWidgetType = c.getInt(WIDGET_TYPE_COLUMN);
+ mVersion = c.getLong(VERSION_COLUMN);
+ }
+
+ private void loadDataContent() {
+ Cursor c = null;
+ mDataList.clear();
+ try {
+ c = mContentResolver.query(Notes.CONTENT_DATA_URI, SqlData.PROJECTION_DATA,
+ "(note_id=?)", new String[] {
+ String.valueOf(mId)
+ }, null);
+ if (c != null) {
+ if (c.getCount() == 0) {
+ Log.w(TAG, "it seems that the note has not data");
+ return;
+ }
+ while (c.moveToNext()) {
+ SqlData data = new SqlData(mContext, c);
+ mDataList.add(data);
+ }
+ } else {
+ Log.w(TAG, "loadDataContent: cursor = null");
+ }
+ } finally {
+ if (c != null)
+ c.close();
+ }
+ }
+
+ public boolean setContent(JSONObject js) {
+ try {
+ JSONObject note = js.getJSONObject(GTaskStringUtils.META_HEAD_NOTE);
+ if (note.getInt(NoteColumns.TYPE) == Notes.TYPE_SYSTEM) {
+ Log.w(TAG, "cannot set system folder");
+ } else if (note.getInt(NoteColumns.TYPE) == Notes.TYPE_FOLDER) {
+ // for folder we can only update the snnipet and type
+ String snippet = note.has(NoteColumns.SNIPPET) ? note
+ .getString(NoteColumns.SNIPPET) : "";
+ if (mIsCreate || !mSnippet.equals(snippet)) {
+ mDiffNoteValues.put(NoteColumns.SNIPPET, snippet);
+ }
+ mSnippet = snippet;
+
+ int type = note.has(NoteColumns.TYPE) ? note.getInt(NoteColumns.TYPE)
+ : Notes.TYPE_NOTE;
+ if (mIsCreate || mType != type) {
+ mDiffNoteValues.put(NoteColumns.TYPE, type);
+ }
+ mType = type;
+ } else if (note.getInt(NoteColumns.TYPE) == Notes.TYPE_NOTE) {
+ JSONArray dataArray = js.getJSONArray(GTaskStringUtils.META_HEAD_DATA);
+ long id = note.has(NoteColumns.ID) ? note.getLong(NoteColumns.ID) : INVALID_ID;
+ if (mIsCreate || mId != id) {
+ mDiffNoteValues.put(NoteColumns.ID, id);
+ }
+ mId = id;
+
+ long alertDate = note.has(NoteColumns.ALERTED_DATE) ? note
+ .getLong(NoteColumns.ALERTED_DATE) : 0;
+ if (mIsCreate || mAlertDate != alertDate) {
+ mDiffNoteValues.put(NoteColumns.ALERTED_DATE, alertDate);
+ }
+ mAlertDate = alertDate;
+
+ int bgColorId = note.has(NoteColumns.BG_COLOR_ID) ? note
+ .getInt(NoteColumns.BG_COLOR_ID) : ResourceParser.getDefaultBgId(mContext);
+ if (mIsCreate || mBgColorId != bgColorId) {
+ mDiffNoteValues.put(NoteColumns.BG_COLOR_ID, bgColorId);
+ }
+ mBgColorId = bgColorId;
+
+ long createDate = note.has(NoteColumns.CREATED_DATE) ? note
+ .getLong(NoteColumns.CREATED_DATE) : System.currentTimeMillis();
+ if (mIsCreate || mCreatedDate != createDate) {
+ mDiffNoteValues.put(NoteColumns.CREATED_DATE, createDate);
+ }
+ mCreatedDate = createDate;
+
+ int hasAttachment = note.has(NoteColumns.HAS_ATTACHMENT) ? note
+ .getInt(NoteColumns.HAS_ATTACHMENT) : 0;
+ if (mIsCreate || mHasAttachment != hasAttachment) {
+ mDiffNoteValues.put(NoteColumns.HAS_ATTACHMENT, hasAttachment);
+ }
+ mHasAttachment = hasAttachment;
+
+ long modifiedDate = note.has(NoteColumns.MODIFIED_DATE) ? note
+ .getLong(NoteColumns.MODIFIED_DATE) : System.currentTimeMillis();
+ if (mIsCreate || mModifiedDate != modifiedDate) {
+ mDiffNoteValues.put(NoteColumns.MODIFIED_DATE, modifiedDate);
+ }
+ mModifiedDate = modifiedDate;
+
+ long parentId = note.has(NoteColumns.PARENT_ID) ? note
+ .getLong(NoteColumns.PARENT_ID) : 0;
+ if (mIsCreate || mParentId != parentId) {
+ mDiffNoteValues.put(NoteColumns.PARENT_ID, parentId);
+ }
+ mParentId = parentId;
+
+ String snippet = note.has(NoteColumns.SNIPPET) ? note
+ .getString(NoteColumns.SNIPPET) : "";
+ if (mIsCreate || !mSnippet.equals(snippet)) {
+ mDiffNoteValues.put(NoteColumns.SNIPPET, snippet);
+ }
+ mSnippet = snippet;
+
+ int type = note.has(NoteColumns.TYPE) ? note.getInt(NoteColumns.TYPE)
+ : Notes.TYPE_NOTE;
+ if (mIsCreate || mType != type) {
+ mDiffNoteValues.put(NoteColumns.TYPE, type);
+ }
+ mType = type;
+
+ int widgetId = note.has(NoteColumns.WIDGET_ID) ? note.getInt(NoteColumns.WIDGET_ID)
+ : AppWidgetManager.INVALID_APPWIDGET_ID;
+ if (mIsCreate || mWidgetId != widgetId) {
+ mDiffNoteValues.put(NoteColumns.WIDGET_ID, widgetId);
+ }
+ mWidgetId = widgetId;
+
+ int widgetType = note.has(NoteColumns.WIDGET_TYPE) ? note
+ .getInt(NoteColumns.WIDGET_TYPE) : Notes.TYPE_WIDGET_INVALIDE;
+ if (mIsCreate || mWidgetType != widgetType) {
+ mDiffNoteValues.put(NoteColumns.WIDGET_TYPE, widgetType);
+ }
+ mWidgetType = widgetType;
+
+ long originParent = note.has(NoteColumns.ORIGIN_PARENT_ID) ? note
+ .getLong(NoteColumns.ORIGIN_PARENT_ID) : 0;
+ if (mIsCreate || mOriginParent != originParent) {
+ mDiffNoteValues.put(NoteColumns.ORIGIN_PARENT_ID, originParent);
+ }
+ mOriginParent = originParent;
+
+ for (int i = 0; i < dataArray.length(); i++) {
+ JSONObject data = dataArray.getJSONObject(i);
+ SqlData sqlData = null;
+ if (data.has(DataColumns.ID)) {
+ long dataId = data.getLong(DataColumns.ID);
+ for (SqlData temp : mDataList) {
+ if (dataId == temp.getId()) {
+ sqlData = temp;
+ }
+ }
+ }
+
+ if (sqlData == null) {
+ sqlData = new SqlData(mContext);
+ mDataList.add(sqlData);
+ }
+
+ sqlData.setContent(data);
+ }
+ }
+ } catch (JSONException e) {
+ Log.e(TAG, e.toString());
+ e.printStackTrace();
+ return false;
+ }
+ return true;
+ }
+
+ public JSONObject getContent() {
+ try {
+ JSONObject js = new JSONObject();
+
+ if (mIsCreate) {
+ Log.e(TAG, "it seems that we haven't created this in database yet");
+ return null;
+ }
+
+ JSONObject note = new JSONObject();
+ if (mType == Notes.TYPE_NOTE) {
+ note.put(NoteColumns.ID, mId);
+ note.put(NoteColumns.ALERTED_DATE, mAlertDate);
+ note.put(NoteColumns.BG_COLOR_ID, mBgColorId);
+ note.put(NoteColumns.CREATED_DATE, mCreatedDate);
+ note.put(NoteColumns.HAS_ATTACHMENT, mHasAttachment);
+ note.put(NoteColumns.MODIFIED_DATE, mModifiedDate);
+ note.put(NoteColumns.PARENT_ID, mParentId);
+ note.put(NoteColumns.SNIPPET, mSnippet);
+ note.put(NoteColumns.TYPE, mType);
+ note.put(NoteColumns.WIDGET_ID, mWidgetId);
+ note.put(NoteColumns.WIDGET_TYPE, mWidgetType);
+ note.put(NoteColumns.ORIGIN_PARENT_ID, mOriginParent);
+ js.put(GTaskStringUtils.META_HEAD_NOTE, note);
+
+ JSONArray dataArray = new JSONArray();
+ for (SqlData sqlData : mDataList) {
+ JSONObject data = sqlData.getContent();
+ if (data != null) {
+ dataArray.put(data);
+ }
+ }
+ js.put(GTaskStringUtils.META_HEAD_DATA, dataArray);
+ } else if (mType == Notes.TYPE_FOLDER || mType == Notes.TYPE_SYSTEM) {
+ note.put(NoteColumns.ID, mId);
+ note.put(NoteColumns.TYPE, mType);
+ note.put(NoteColumns.SNIPPET, mSnippet);
+ js.put(GTaskStringUtils.META_HEAD_NOTE, note);
+ }
+
+ return js;
+ } catch (JSONException e) {
+ Log.e(TAG, e.toString());
+ e.printStackTrace();
+ }
+ return null;
+ }
+
+ public void setParentId(long id) {
+ mParentId = id;
+ mDiffNoteValues.put(NoteColumns.PARENT_ID, id);
+ }
+
+ public void setGtaskId(String gid) {
+ mDiffNoteValues.put(NoteColumns.GTASK_ID, gid);
+ }
+
+ public void setSyncId(long syncId) {
+ mDiffNoteValues.put(NoteColumns.SYNC_ID, syncId);
+ }
+
+ public void resetLocalModified() {
+ mDiffNoteValues.put(NoteColumns.LOCAL_MODIFIED, 0);
+ }
+
+ public long getId() {
+ return mId;
+ }
+
+ public long getParentId() {
+ return mParentId;
+ }
+
+ public String getSnippet() {
+ return mSnippet;
+ }
+
+ public boolean isNoteType() {
+ return mType == Notes.TYPE_NOTE;
+ }
+
+ public void commit(boolean validateVersion) {
+ if (mIsCreate) {
+ if (mId == INVALID_ID && mDiffNoteValues.containsKey(NoteColumns.ID)) {
+ mDiffNoteValues.remove(NoteColumns.ID);
+ }
+
+ Uri uri = mContentResolver.insert(Notes.CONTENT_NOTE_URI, mDiffNoteValues);
+ try {
+ mId = Long.valueOf(uri.getPathSegments().get(1));
+ } catch (NumberFormatException e) {
+ Log.e(TAG, "Get note id error :" + e.toString());
+ throw new ActionFailureException("create note failed");
+ }
+ if (mId == 0) {
+ throw new IllegalStateException("Create thread id failed");
+ }
+
+ if (mType == Notes.TYPE_NOTE) {
+ for (SqlData sqlData : mDataList) {
+ sqlData.commit(mId, false, -1);
+ }
+ }
+ } else {
+ if (mId <= 0 && mId != Notes.ID_ROOT_FOLDER && mId != Notes.ID_CALL_RECORD_FOLDER) {
+ Log.e(TAG, "No such note");
+ throw new IllegalStateException("Try to update note with invalid id");
+ }
+ if (mDiffNoteValues.size() > 0) {
+ mVersion ++;
+ int result = 0;
+ if (!validateVersion) {
+ result = mContentResolver.update(Notes.CONTENT_NOTE_URI, mDiffNoteValues, "("
+ + NoteColumns.ID + "=?)", new String[] {
+ String.valueOf(mId)
+ });
+ } else {
+ result = mContentResolver.update(Notes.CONTENT_NOTE_URI, mDiffNoteValues, "("
+ + NoteColumns.ID + "=?) AND (" + NoteColumns.VERSION + "<=?)",
+ new String[] {
+ String.valueOf(mId), String.valueOf(mVersion)
+ });
+ }
+ if (result == 0) {
+ Log.w(TAG, "there is no update. maybe user updates note when syncing");
+ }
+ }
+
+ if (mType == Notes.TYPE_NOTE) {
+ for (SqlData sqlData : mDataList) {
+ sqlData.commit(mId, validateVersion, mVersion);
+ }
+ }
+ }
+
+ // refresh local info
+ loadFromCursor(mId);
+ if (mType == Notes.TYPE_NOTE)
+ loadDataContent();
+
+ mDiffNoteValues.clear();
+ mIsCreate = false;
+ }
+}
diff --git a/src/src/Notes-master/src/net/micode/notes/gtask/data/Task.java b/src/src/Notes-master/src/net/micode/notes/gtask/data/Task.java
new file mode 100644
index 0000000..6a19454
--- /dev/null
+++ b/src/src/Notes-master/src/net/micode/notes/gtask/data/Task.java
@@ -0,0 +1,351 @@
+/*
+ * Copyright (c) 2010-2011, The MiCode Open Source Community (www.micode.net)
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+
+package net.micode.notes.gtask.data;
+
+import android.database.Cursor;
+import android.text.TextUtils;
+import android.util.Log;
+
+import net.micode.notes.data.Notes;
+import net.micode.notes.data.Notes.DataColumns;
+import net.micode.notes.data.Notes.DataConstants;
+import net.micode.notes.data.Notes.NoteColumns;
+import net.micode.notes.gtask.exception.ActionFailureException;
+import net.micode.notes.tool.GTaskStringUtils;
+
+import org.json.JSONArray;
+import org.json.JSONException;
+import org.json.JSONObject;
+
+
+public class Task extends Node {
+ private static final String TAG = Task.class.getSimpleName();
+
+ private boolean mCompleted;
+
+ private String mNotes;
+
+ private JSONObject mMetaInfo;
+
+ private Task mPriorSibling;
+
+ private TaskList mParent;
+
+ public Task() {
+ super();
+ mCompleted = false;
+ mNotes = null;
+ mPriorSibling = null;
+ mParent = null;
+ mMetaInfo = null;
+ }
+
+ public JSONObject getCreateAction(int actionId) {
+ JSONObject js = new JSONObject();
+
+ try {
+ // action_type
+ js.put(GTaskStringUtils.GTASK_JSON_ACTION_TYPE,
+ GTaskStringUtils.GTASK_JSON_ACTION_TYPE_CREATE);
+
+ // action_id
+ js.put(GTaskStringUtils.GTASK_JSON_ACTION_ID, actionId);
+
+ // index
+ js.put(GTaskStringUtils.GTASK_JSON_INDEX, mParent.getChildTaskIndex(this));
+
+ // entity_delta
+ JSONObject entity = new JSONObject();
+ entity.put(GTaskStringUtils.GTASK_JSON_NAME, getName());
+ entity.put(GTaskStringUtils.GTASK_JSON_CREATOR_ID, "null");
+ entity.put(GTaskStringUtils.GTASK_JSON_ENTITY_TYPE,
+ GTaskStringUtils.GTASK_JSON_TYPE_TASK);
+ if (getNotes() != null) {
+ entity.put(GTaskStringUtils.GTASK_JSON_NOTES, getNotes());
+ }
+ js.put(GTaskStringUtils.GTASK_JSON_ENTITY_DELTA, entity);
+
+ // parent_id
+ js.put(GTaskStringUtils.GTASK_JSON_PARENT_ID, mParent.getGid());
+
+ // dest_parent_type
+ js.put(GTaskStringUtils.GTASK_JSON_DEST_PARENT_TYPE,
+ GTaskStringUtils.GTASK_JSON_TYPE_GROUP);
+
+ // list_id
+ js.put(GTaskStringUtils.GTASK_JSON_LIST_ID, mParent.getGid());
+
+ // prior_sibling_id
+ if (mPriorSibling != null) {
+ js.put(GTaskStringUtils.GTASK_JSON_PRIOR_SIBLING_ID, mPriorSibling.getGid());
+ }
+
+ } catch (JSONException e) {
+ Log.e(TAG, e.toString());
+ e.printStackTrace();
+ throw new ActionFailureException("fail to generate task-create jsonobject");
+ }
+
+ return js;
+ }
+
+ public JSONObject getUpdateAction(int actionId) {
+ JSONObject js = new JSONObject();
+
+ try {
+ // action_type
+ js.put(GTaskStringUtils.GTASK_JSON_ACTION_TYPE,
+ GTaskStringUtils.GTASK_JSON_ACTION_TYPE_UPDATE);
+
+ // action_id
+ js.put(GTaskStringUtils.GTASK_JSON_ACTION_ID, actionId);
+
+ // id
+ js.put(GTaskStringUtils.GTASK_JSON_ID, getGid());
+
+ // entity_delta
+ JSONObject entity = new JSONObject();
+ entity.put(GTaskStringUtils.GTASK_JSON_NAME, getName());
+ if (getNotes() != null) {
+ entity.put(GTaskStringUtils.GTASK_JSON_NOTES, getNotes());
+ }
+ entity.put(GTaskStringUtils.GTASK_JSON_DELETED, getDeleted());
+ js.put(GTaskStringUtils.GTASK_JSON_ENTITY_DELTA, entity);
+
+ } catch (JSONException e) {
+ Log.e(TAG, e.toString());
+ e.printStackTrace();
+ throw new ActionFailureException("fail to generate task-update jsonobject");
+ }
+
+ return js;
+ }
+
+ public void setContentByRemoteJSON(JSONObject js) {
+ if (js != null) {
+ try {
+ // id
+ if (js.has(GTaskStringUtils.GTASK_JSON_ID)) {
+ setGid(js.getString(GTaskStringUtils.GTASK_JSON_ID));
+ }
+
+ // last_modified
+ if (js.has(GTaskStringUtils.GTASK_JSON_LAST_MODIFIED)) {
+ setLastModified(js.getLong(GTaskStringUtils.GTASK_JSON_LAST_MODIFIED));
+ }
+
+ // name
+ if (js.has(GTaskStringUtils.GTASK_JSON_NAME)) {
+ setName(js.getString(GTaskStringUtils.GTASK_JSON_NAME));
+ }
+
+ // notes
+ if (js.has(GTaskStringUtils.GTASK_JSON_NOTES)) {
+ setNotes(js.getString(GTaskStringUtils.GTASK_JSON_NOTES));
+ }
+
+ // deleted
+ if (js.has(GTaskStringUtils.GTASK_JSON_DELETED)) {
+ setDeleted(js.getBoolean(GTaskStringUtils.GTASK_JSON_DELETED));
+ }
+
+ // completed
+ if (js.has(GTaskStringUtils.GTASK_JSON_COMPLETED)) {
+ setCompleted(js.getBoolean(GTaskStringUtils.GTASK_JSON_COMPLETED));
+ }
+ } catch (JSONException e) {
+ Log.e(TAG, e.toString());
+ e.printStackTrace();
+ throw new ActionFailureException("fail to get task content from jsonobject");
+ }
+ }
+ }
+
+ public void setContentByLocalJSON(JSONObject js) {
+ if (js == null || !js.has(GTaskStringUtils.META_HEAD_NOTE)
+ || !js.has(GTaskStringUtils.META_HEAD_DATA)) {
+ Log.w(TAG, "setContentByLocalJSON: nothing is avaiable");
+ }
+
+ try {
+ JSONObject note = js.getJSONObject(GTaskStringUtils.META_HEAD_NOTE);
+ JSONArray dataArray = js.getJSONArray(GTaskStringUtils.META_HEAD_DATA);
+
+ if (note.getInt(NoteColumns.TYPE) != Notes.TYPE_NOTE) {
+ Log.e(TAG, "invalid type");
+ return;
+ }
+
+ for (int i = 0; i < dataArray.length(); i++) {
+ JSONObject data = dataArray.getJSONObject(i);
+ if (TextUtils.equals(data.getString(DataColumns.MIME_TYPE), DataConstants.NOTE)) {
+ setName(data.getString(DataColumns.CONTENT));
+ break;
+ }
+ }
+
+ } catch (JSONException e) {
+ Log.e(TAG, e.toString());
+ e.printStackTrace();
+ }
+ }
+
+ public JSONObject getLocalJSONFromContent() {
+ String name = getName();
+ try {
+ if (mMetaInfo == null) {
+ // new task created from web
+ if (name == null) {
+ Log.w(TAG, "the note seems to be an empty one");
+ return null;
+ }
+
+ JSONObject js = new JSONObject();
+ JSONObject note = new JSONObject();
+ JSONArray dataArray = new JSONArray();
+ JSONObject data = new JSONObject();
+ data.put(DataColumns.CONTENT, name);
+ dataArray.put(data);
+ js.put(GTaskStringUtils.META_HEAD_DATA, dataArray);
+ note.put(NoteColumns.TYPE, Notes.TYPE_NOTE);
+ js.put(GTaskStringUtils.META_HEAD_NOTE, note);
+ return js;
+ } else {
+ // synced task
+ JSONObject note = mMetaInfo.getJSONObject(GTaskStringUtils.META_HEAD_NOTE);
+ JSONArray dataArray = mMetaInfo.getJSONArray(GTaskStringUtils.META_HEAD_DATA);
+
+ for (int i = 0; i < dataArray.length(); i++) {
+ JSONObject data = dataArray.getJSONObject(i);
+ if (TextUtils.equals(data.getString(DataColumns.MIME_TYPE), DataConstants.NOTE)) {
+ data.put(DataColumns.CONTENT, getName());
+ break;
+ }
+ }
+
+ note.put(NoteColumns.TYPE, Notes.TYPE_NOTE);
+ return mMetaInfo;
+ }
+ } catch (JSONException e) {
+ Log.e(TAG, e.toString());
+ e.printStackTrace();
+ return null;
+ }
+ }
+
+ public void setMetaInfo(MetaData metaData) {
+ if (metaData != null && metaData.getNotes() != null) {
+ try {
+ mMetaInfo = new JSONObject(metaData.getNotes());
+ } catch (JSONException e) {
+ Log.w(TAG, e.toString());
+ mMetaInfo = null;
+ }
+ }
+ }
+
+ public int getSyncAction(Cursor c) {
+ try {
+ JSONObject noteInfo = null;
+ if (mMetaInfo != null && mMetaInfo.has(GTaskStringUtils.META_HEAD_NOTE)) {
+ noteInfo = mMetaInfo.getJSONObject(GTaskStringUtils.META_HEAD_NOTE);
+ }
+
+ if (noteInfo == null) {
+ Log.w(TAG, "it seems that note meta has been deleted");
+ return SYNC_ACTION_UPDATE_REMOTE;
+ }
+
+ if (!noteInfo.has(NoteColumns.ID)) {
+ Log.w(TAG, "remote note id seems to be deleted");
+ return SYNC_ACTION_UPDATE_LOCAL;
+ }
+
+ // validate the note id now
+ if (c.getLong(SqlNote.ID_COLUMN) != noteInfo.getLong(NoteColumns.ID)) {
+ Log.w(TAG, "note id doesn't match");
+ return SYNC_ACTION_UPDATE_LOCAL;
+ }
+
+ if (c.getInt(SqlNote.LOCAL_MODIFIED_COLUMN) == 0) {
+ // there is no local update
+ if (c.getLong(SqlNote.SYNC_ID_COLUMN) == getLastModified()) {
+ // no update both side
+ return SYNC_ACTION_NONE;
+ } else {
+ // apply remote to local
+ return SYNC_ACTION_UPDATE_LOCAL;
+ }
+ } else {
+ // validate gtask id
+ if (!c.getString(SqlNote.GTASK_ID_COLUMN).equals(getGid())) {
+ Log.e(TAG, "gtask id doesn't match");
+ return SYNC_ACTION_ERROR;
+ }
+ if (c.getLong(SqlNote.SYNC_ID_COLUMN) == getLastModified()) {
+ // local modification only
+ return SYNC_ACTION_UPDATE_REMOTE;
+ } else {
+ return SYNC_ACTION_UPDATE_CONFLICT;
+ }
+ }
+ } catch (Exception e) {
+ Log.e(TAG, e.toString());
+ e.printStackTrace();
+ }
+
+ return SYNC_ACTION_ERROR;
+ }
+
+ public boolean isWorthSaving() {
+ return mMetaInfo != null || (getName() != null && getName().trim().length() > 0)
+ || (getNotes() != null && getNotes().trim().length() > 0);
+ }
+
+ public void setCompleted(boolean completed) {
+ this.mCompleted = completed;
+ }
+
+ public void setNotes(String notes) {
+ this.mNotes = notes;
+ }
+
+ public void setPriorSibling(Task priorSibling) {
+ this.mPriorSibling = priorSibling;
+ }
+
+ public void setParent(TaskList parent) {
+ this.mParent = parent;
+ }
+
+ public boolean getCompleted() {
+ return this.mCompleted;
+ }
+
+ public String getNotes() {
+ return this.mNotes;
+ }
+
+ public Task getPriorSibling() {
+ return this.mPriorSibling;
+ }
+
+ public TaskList getParent() {
+ return this.mParent;
+ }
+
+}
diff --git a/src/src/Notes-master/src/net/micode/notes/gtask/data/TaskList.java b/src/src/Notes-master/src/net/micode/notes/gtask/data/TaskList.java
new file mode 100644
index 0000000..4ea21c5
--- /dev/null
+++ b/src/src/Notes-master/src/net/micode/notes/gtask/data/TaskList.java
@@ -0,0 +1,343 @@
+/*
+ * Copyright (c) 2010-2011, The MiCode Open Source Community (www.micode.net)
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+
+package net.micode.notes.gtask.data;
+
+import android.database.Cursor;
+import android.util.Log;
+
+import net.micode.notes.data.Notes;
+import net.micode.notes.data.Notes.NoteColumns;
+import net.micode.notes.gtask.exception.ActionFailureException;
+import net.micode.notes.tool.GTaskStringUtils;
+
+import org.json.JSONException;
+import org.json.JSONObject;
+
+import java.util.ArrayList;
+
+
+public class TaskList extends Node {
+ private static final String TAG = TaskList.class.getSimpleName();
+
+ private int mIndex;
+
+ private ArrayList mChildren;
+
+ public TaskList() {
+ super();
+ mChildren = new ArrayList();
+ mIndex = 1;
+ }
+
+ public JSONObject getCreateAction(int actionId) {
+ JSONObject js = new JSONObject();
+
+ try {
+ // action_type
+ js.put(GTaskStringUtils.GTASK_JSON_ACTION_TYPE,
+ GTaskStringUtils.GTASK_JSON_ACTION_TYPE_CREATE);
+
+ // action_id
+ js.put(GTaskStringUtils.GTASK_JSON_ACTION_ID, actionId);
+
+ // index
+ js.put(GTaskStringUtils.GTASK_JSON_INDEX, mIndex);
+
+ // entity_delta
+ JSONObject entity = new JSONObject();
+ entity.put(GTaskStringUtils.GTASK_JSON_NAME, getName());
+ entity.put(GTaskStringUtils.GTASK_JSON_CREATOR_ID, "null");
+ entity.put(GTaskStringUtils.GTASK_JSON_ENTITY_TYPE,
+ GTaskStringUtils.GTASK_JSON_TYPE_GROUP);
+ js.put(GTaskStringUtils.GTASK_JSON_ENTITY_DELTA, entity);
+
+ } catch (JSONException e) {
+ Log.e(TAG, e.toString());
+ e.printStackTrace();
+ throw new ActionFailureException("fail to generate tasklist-create jsonobject");
+ }
+
+ return js;
+ }
+
+ public JSONObject getUpdateAction(int actionId) {
+ JSONObject js = new JSONObject();
+
+ try {
+ // action_type
+ js.put(GTaskStringUtils.GTASK_JSON_ACTION_TYPE,
+ GTaskStringUtils.GTASK_JSON_ACTION_TYPE_UPDATE);
+
+ // action_id
+ js.put(GTaskStringUtils.GTASK_JSON_ACTION_ID, actionId);
+
+ // id
+ js.put(GTaskStringUtils.GTASK_JSON_ID, getGid());
+
+ // entity_delta
+ JSONObject entity = new JSONObject();
+ entity.put(GTaskStringUtils.GTASK_JSON_NAME, getName());
+ entity.put(GTaskStringUtils.GTASK_JSON_DELETED, getDeleted());
+ js.put(GTaskStringUtils.GTASK_JSON_ENTITY_DELTA, entity);
+
+ } catch (JSONException e) {
+ Log.e(TAG, e.toString());
+ e.printStackTrace();
+ throw new ActionFailureException("fail to generate tasklist-update jsonobject");
+ }
+
+ return js;
+ }
+
+ public void setContentByRemoteJSON(JSONObject js) {
+ if (js != null) {
+ try {
+ // id
+ if (js.has(GTaskStringUtils.GTASK_JSON_ID)) {
+ setGid(js.getString(GTaskStringUtils.GTASK_JSON_ID));
+ }
+
+ // last_modified
+ if (js.has(GTaskStringUtils.GTASK_JSON_LAST_MODIFIED)) {
+ setLastModified(js.getLong(GTaskStringUtils.GTASK_JSON_LAST_MODIFIED));
+ }
+
+ // name
+ if (js.has(GTaskStringUtils.GTASK_JSON_NAME)) {
+ setName(js.getString(GTaskStringUtils.GTASK_JSON_NAME));
+ }
+
+ } catch (JSONException e) {
+ Log.e(TAG, e.toString());
+ e.printStackTrace();
+ throw new ActionFailureException("fail to get tasklist content from jsonobject");
+ }
+ }
+ }
+
+ public void setContentByLocalJSON(JSONObject js) {
+ if (js == null || !js.has(GTaskStringUtils.META_HEAD_NOTE)) {
+ Log.w(TAG, "setContentByLocalJSON: nothing is avaiable");
+ }
+
+ try {
+ JSONObject folder = js.getJSONObject(GTaskStringUtils.META_HEAD_NOTE);
+
+ if (folder.getInt(NoteColumns.TYPE) == Notes.TYPE_FOLDER) {
+ String name = folder.getString(NoteColumns.SNIPPET);
+ setName(GTaskStringUtils.MIUI_FOLDER_PREFFIX + name);
+ } else if (folder.getInt(NoteColumns.TYPE) == Notes.TYPE_SYSTEM) {
+ if (folder.getLong(NoteColumns.ID) == Notes.ID_ROOT_FOLDER)
+ setName(GTaskStringUtils.MIUI_FOLDER_PREFFIX + GTaskStringUtils.FOLDER_DEFAULT);
+ else if (folder.getLong(NoteColumns.ID) == Notes.ID_CALL_RECORD_FOLDER)
+ setName(GTaskStringUtils.MIUI_FOLDER_PREFFIX
+ + GTaskStringUtils.FOLDER_CALL_NOTE);
+ else
+ Log.e(TAG, "invalid system folder");
+ } else {
+ Log.e(TAG, "error type");
+ }
+ } catch (JSONException e) {
+ Log.e(TAG, e.toString());
+ e.printStackTrace();
+ }
+ }
+
+ public JSONObject getLocalJSONFromContent() {
+ try {
+ JSONObject js = new JSONObject();
+ JSONObject folder = new JSONObject();
+
+ String folderName = getName();
+ if (getName().startsWith(GTaskStringUtils.MIUI_FOLDER_PREFFIX))
+ folderName = folderName.substring(GTaskStringUtils.MIUI_FOLDER_PREFFIX.length(),
+ folderName.length());
+ folder.put(NoteColumns.SNIPPET, folderName);
+ if (folderName.equals(GTaskStringUtils.FOLDER_DEFAULT)
+ || folderName.equals(GTaskStringUtils.FOLDER_CALL_NOTE))
+ folder.put(NoteColumns.TYPE, Notes.TYPE_SYSTEM);
+ else
+ folder.put(NoteColumns.TYPE, Notes.TYPE_FOLDER);
+
+ js.put(GTaskStringUtils.META_HEAD_NOTE, folder);
+
+ return js;
+ } catch (JSONException e) {
+ Log.e(TAG, e.toString());
+ e.printStackTrace();
+ return null;
+ }
+ }
+
+ public int getSyncAction(Cursor c) {
+ try {
+ if (c.getInt(SqlNote.LOCAL_MODIFIED_COLUMN) == 0) {
+ // there is no local update
+ if (c.getLong(SqlNote.SYNC_ID_COLUMN) == getLastModified()) {
+ // no update both side
+ return SYNC_ACTION_NONE;
+ } else {
+ // apply remote to local
+ return SYNC_ACTION_UPDATE_LOCAL;
+ }
+ } else {
+ // validate gtask id
+ if (!c.getString(SqlNote.GTASK_ID_COLUMN).equals(getGid())) {
+ Log.e(TAG, "gtask id doesn't match");
+ return SYNC_ACTION_ERROR;
+ }
+ if (c.getLong(SqlNote.SYNC_ID_COLUMN) == getLastModified()) {
+ // local modification only
+ return SYNC_ACTION_UPDATE_REMOTE;
+ } else {
+ // for folder conflicts, just apply local modification
+ return SYNC_ACTION_UPDATE_REMOTE;
+ }
+ }
+ } catch (Exception e) {
+ Log.e(TAG, e.toString());
+ e.printStackTrace();
+ }
+
+ return SYNC_ACTION_ERROR;
+ }
+
+ public int getChildTaskCount() {
+ return mChildren.size();
+ }
+
+ public boolean addChildTask(Task task) {
+ boolean ret = false;
+ if (task != null && !mChildren.contains(task)) {
+ ret = mChildren.add(task);
+ if (ret) {
+ // need to set prior sibling and parent
+ task.setPriorSibling(mChildren.isEmpty() ? null : mChildren
+ .get(mChildren.size() - 1));
+ task.setParent(this);
+ }
+ }
+ return ret;
+ }
+
+ public boolean addChildTask(Task task, int index) {
+ if (index < 0 || index > mChildren.size()) {
+ Log.e(TAG, "add child task: invalid index");
+ return false;
+ }
+
+ int pos = mChildren.indexOf(task);
+ if (task != null && pos == -1) {
+ mChildren.add(index, task);
+
+ // update the task list
+ Task preTask = null;
+ Task afterTask = null;
+ if (index != 0)
+ preTask = mChildren.get(index - 1);
+ if (index != mChildren.size() - 1)
+ afterTask = mChildren.get(index + 1);
+
+ task.setPriorSibling(preTask);
+ if (afterTask != null)
+ afterTask.setPriorSibling(task);
+ }
+
+ return true;
+ }
+
+ public boolean removeChildTask(Task task) {
+ boolean ret = false;
+ int index = mChildren.indexOf(task);
+ if (index != -1) {
+ ret = mChildren.remove(task);
+
+ if (ret) {
+ // reset prior sibling and parent
+ task.setPriorSibling(null);
+ task.setParent(null);
+
+ // update the task list
+ if (index != mChildren.size()) {
+ mChildren.get(index).setPriorSibling(
+ index == 0 ? null : mChildren.get(index - 1));
+ }
+ }
+ }
+ return ret;
+ }
+
+ public boolean moveChildTask(Task task, int index) {
+
+ if (index < 0 || index >= mChildren.size()) {
+ Log.e(TAG, "move child task: invalid index");
+ return false;
+ }
+
+ int pos = mChildren.indexOf(task);
+ if (pos == -1) {
+ Log.e(TAG, "move child task: the task should in the list");
+ return false;
+ }
+
+ if (pos == index)
+ return true;
+ return (removeChildTask(task) && addChildTask(task, index));
+ }
+
+ public Task findChildTaskByGid(String gid) {
+ for (int i = 0; i < mChildren.size(); i++) {
+ Task t = mChildren.get(i);
+ if (t.getGid().equals(gid)) {
+ return t;
+ }
+ }
+ return null;
+ }
+
+ public int getChildTaskIndex(Task task) {
+ return mChildren.indexOf(task);
+ }
+
+ public Task getChildTaskByIndex(int index) {
+ if (index < 0 || index >= mChildren.size()) {
+ Log.e(TAG, "getTaskByIndex: invalid index");
+ return null;
+ }
+ return mChildren.get(index);
+ }
+
+ public Task getChilTaskByGid(String gid) {
+ for (Task task : mChildren) {
+ if (task.getGid().equals(gid))
+ return task;
+ }
+ return null;
+ }
+
+ public ArrayList getChildTaskList() {
+ return this.mChildren;
+ }
+
+ public void setIndex(int index) {
+ this.mIndex = index;
+ }
+
+ public int getIndex() {
+ return this.mIndex;
+ }
+}
diff --git a/src/src/Notes-master/src/net/micode/notes/gtask/exception/ActionFailureException.java b/src/src/Notes-master/src/net/micode/notes/gtask/exception/ActionFailureException.java
new file mode 100644
index 0000000..15504be
--- /dev/null
+++ b/src/src/Notes-master/src/net/micode/notes/gtask/exception/ActionFailureException.java
@@ -0,0 +1,33 @@
+/*
+ * Copyright (c) 2010-2011, The MiCode Open Source Community (www.micode.net)
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+
+package net.micode.notes.gtask.exception;
+
+public class ActionFailureException extends RuntimeException {
+ private static final long serialVersionUID = 4425249765923293627L;
+
+ public ActionFailureException() {
+ super();
+ }
+
+ public ActionFailureException(String paramString) {
+ super(paramString);
+ }
+
+ public ActionFailureException(String paramString, Throwable paramThrowable) {
+ super(paramString, paramThrowable);
+ }
+}
diff --git a/src/src/Notes-master/src/net/micode/notes/gtask/exception/NetworkFailureException.java b/src/src/Notes-master/src/net/micode/notes/gtask/exception/NetworkFailureException.java
new file mode 100644
index 0000000..b08cfb1
--- /dev/null
+++ b/src/src/Notes-master/src/net/micode/notes/gtask/exception/NetworkFailureException.java
@@ -0,0 +1,33 @@
+/*
+ * Copyright (c) 2010-2011, The MiCode Open Source Community (www.micode.net)
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+
+package net.micode.notes.gtask.exception;
+
+public class NetworkFailureException extends Exception {
+ private static final long serialVersionUID = 2107610287180234136L;
+
+ public NetworkFailureException() {
+ super();
+ }
+
+ public NetworkFailureException(String paramString) {
+ super(paramString);
+ }
+
+ public NetworkFailureException(String paramString, Throwable paramThrowable) {
+ super(paramString, paramThrowable);
+ }
+}
diff --git a/src/src/Notes-master/src/net/micode/notes/gtask/remote/GTaskASyncTask.java b/src/src/Notes-master/src/net/micode/notes/gtask/remote/GTaskASyncTask.java
new file mode 100644
index 0000000..b3b61e7
--- /dev/null
+++ b/src/src/Notes-master/src/net/micode/notes/gtask/remote/GTaskASyncTask.java
@@ -0,0 +1,123 @@
+
+/*
+ * Copyright (c) 2010-2011, The MiCode Open Source Community (www.micode.net)
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+
+package net.micode.notes.gtask.remote;
+
+import android.app.Notification;
+import android.app.NotificationManager;
+import android.app.PendingIntent;
+import android.content.Context;
+import android.content.Intent;
+import android.os.AsyncTask;
+
+import net.micode.notes.R;
+import net.micode.notes.ui.NotesListActivity;
+import net.micode.notes.ui.NotesPreferenceActivity;
+
+
+public class GTaskASyncTask extends AsyncTask {
+
+ private static int GTASK_SYNC_NOTIFICATION_ID = 5234235;
+
+ public interface OnCompleteListener {
+ void onComplete();
+ }
+
+ private Context mContext;
+
+ private NotificationManager mNotifiManager;
+
+ private GTaskManager mTaskManager;
+
+ private OnCompleteListener mOnCompleteListener;
+
+ public GTaskASyncTask(Context context, OnCompleteListener listener) {
+ mContext = context;
+ mOnCompleteListener = listener;
+ mNotifiManager = (NotificationManager) mContext
+ .getSystemService(Context.NOTIFICATION_SERVICE);
+ mTaskManager = GTaskManager.getInstance();
+ }
+
+ public void cancelSync() {
+ mTaskManager.cancelSync();
+ }
+
+ public void publishProgess(String message) {
+ publishProgress(new String[] {
+ message
+ });
+ }
+
+ private void showNotification(int tickerId, String content) {
+ Notification notification = new Notification(R.drawable.notification, mContext
+ .getString(tickerId), System.currentTimeMillis());
+ notification.defaults = Notification.DEFAULT_LIGHTS;
+ notification.flags = Notification.FLAG_AUTO_CANCEL;
+ PendingIntent pendingIntent;
+ if (tickerId != R.string.ticker_success) {
+ pendingIntent = PendingIntent.getActivity(mContext, 0, new Intent(mContext,
+ NotesPreferenceActivity.class), 0);
+
+ } else {
+ pendingIntent = PendingIntent.getActivity(mContext, 0, new Intent(mContext,
+ NotesListActivity.class), 0);
+ }
+ notification.setLatestEventInfo(mContext, mContext.getString(R.string.app_name), content,
+ pendingIntent);
+ mNotifiManager.notify(GTASK_SYNC_NOTIFICATION_ID, notification);
+ }
+
+ @Override
+ protected Integer doInBackground(Void... unused) {
+ publishProgess(mContext.getString(R.string.sync_progress_login, NotesPreferenceActivity
+ .getSyncAccountName(mContext)));
+ return mTaskManager.sync(mContext, this);
+ }
+
+ @Override
+ protected void onProgressUpdate(String... progress) {
+ showNotification(R.string.ticker_syncing, progress[0]);
+ if (mContext instanceof GTaskSyncService) {
+ ((GTaskSyncService) mContext).sendBroadcast(progress[0]);
+ }
+ }
+
+ @Override
+ protected void onPostExecute(Integer result) {
+ if (result == GTaskManager.STATE_SUCCESS) {
+ showNotification(R.string.ticker_success, mContext.getString(
+ R.string.success_sync_account, mTaskManager.getSyncAccount()));
+ NotesPreferenceActivity.setLastSyncTime(mContext, System.currentTimeMillis());
+ } else if (result == GTaskManager.STATE_NETWORK_ERROR) {
+ showNotification(R.string.ticker_fail, mContext.getString(R.string.error_sync_network));
+ } else if (result == GTaskManager.STATE_INTERNAL_ERROR) {
+ showNotification(R.string.ticker_fail, mContext.getString(R.string.error_sync_internal));
+ } else if (result == GTaskManager.STATE_SYNC_CANCELLED) {
+ showNotification(R.string.ticker_cancel, mContext
+ .getString(R.string.error_sync_cancelled));
+ }
+ if (mOnCompleteListener != null) {
+ new Thread(new Runnable() {
+
+ public void run() {
+ mOnCompleteListener.onComplete();
+ }
+ }).start();
+ }
+ }
+}
diff --git a/src/src/Notes-master/src/net/micode/notes/gtask/remote/GTaskClient.java b/src/src/Notes-master/src/net/micode/notes/gtask/remote/GTaskClient.java
new file mode 100644
index 0000000..c67dfdf
--- /dev/null
+++ b/src/src/Notes-master/src/net/micode/notes/gtask/remote/GTaskClient.java
@@ -0,0 +1,585 @@
+/*
+ * Copyright (c) 2010-2011, The MiCode Open Source Community (www.micode.net)
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+
+package net.micode.notes.gtask.remote;
+
+import android.accounts.Account;
+import android.accounts.AccountManager;
+import android.accounts.AccountManagerFuture;
+import android.app.Activity;
+import android.os.Bundle;
+import android.text.TextUtils;
+import android.util.Log;
+
+import net.micode.notes.gtask.data.Node;
+import net.micode.notes.gtask.data.Task;
+import net.micode.notes.gtask.data.TaskList;
+import net.micode.notes.gtask.exception.ActionFailureException;
+import net.micode.notes.gtask.exception.NetworkFailureException;
+import net.micode.notes.tool.GTaskStringUtils;
+import net.micode.notes.ui.NotesPreferenceActivity;
+
+import org.apache.http.HttpEntity;
+import org.apache.http.HttpResponse;
+import org.apache.http.client.ClientProtocolException;
+import org.apache.http.client.entity.UrlEncodedFormEntity;
+import org.apache.http.client.methods.HttpGet;
+import org.apache.http.client.methods.HttpPost;
+import org.apache.http.cookie.Cookie;
+import org.apache.http.impl.client.BasicCookieStore;
+import org.apache.http.impl.client.DefaultHttpClient;
+import org.apache.http.message.BasicNameValuePair;
+import org.apache.http.params.BasicHttpParams;
+import org.apache.http.params.HttpConnectionParams;
+import org.apache.http.params.HttpParams;
+import org.apache.http.params.HttpProtocolParams;
+import org.json.JSONArray;
+import org.json.JSONException;
+import org.json.JSONObject;
+
+import java.io.BufferedReader;
+import java.io.IOException;
+import java.io.InputStream;
+import java.io.InputStreamReader;
+import java.util.LinkedList;
+import java.util.List;
+import java.util.zip.GZIPInputStream;
+import java.util.zip.Inflater;
+import java.util.zip.InflaterInputStream;
+
+
+public class GTaskClient {
+ private static final String TAG = GTaskClient.class.getSimpleName();
+
+ private static final String GTASK_URL = "https://mail.google.com/tasks/";
+
+ private static final String GTASK_GET_URL = "https://mail.google.com/tasks/ig";
+
+ private static final String GTASK_POST_URL = "https://mail.google.com/tasks/r/ig";
+
+ private static GTaskClient mInstance = null;
+
+ private DefaultHttpClient mHttpClient;
+
+ private String mGetUrl;
+
+ private String mPostUrl;
+
+ private long mClientVersion;
+
+ private boolean mLoggedin;
+
+ private long mLastLoginTime;
+
+ private int mActionId;
+
+ private Account mAccount;
+
+ private JSONArray mUpdateArray;
+
+ private GTaskClient() {
+ mHttpClient = null;
+ mGetUrl = GTASK_GET_URL;
+ mPostUrl = GTASK_POST_URL;
+ mClientVersion = -1;
+ mLoggedin = false;
+ mLastLoginTime = 0;
+ mActionId = 1;
+ mAccount = null;
+ mUpdateArray = null;
+ }
+
+ public static synchronized GTaskClient getInstance() {
+ if (mInstance == null) {
+ mInstance = new GTaskClient();
+ }
+ return mInstance;
+ }
+
+ public boolean login(Activity activity) {
+ // we suppose that the cookie would expire after 5 minutes
+ // then we need to re-login
+ final long interval = 1000 * 60 * 5;
+ if (mLastLoginTime + interval < System.currentTimeMillis()) {
+ mLoggedin = false;
+ }
+
+ // need to re-login after account switch
+ if (mLoggedin
+ && !TextUtils.equals(getSyncAccount().name, NotesPreferenceActivity
+ .getSyncAccountName(activity))) {
+ mLoggedin = false;
+ }
+
+ if (mLoggedin) {
+ Log.d(TAG, "already logged in");
+ return true;
+ }
+
+ mLastLoginTime = System.currentTimeMillis();
+ String authToken = loginGoogleAccount(activity, false);
+ if (authToken == null) {
+ Log.e(TAG, "login google account failed");
+ return false;
+ }
+
+ // login with custom domain if necessary
+ if (!(mAccount.name.toLowerCase().endsWith("gmail.com") || mAccount.name.toLowerCase()
+ .endsWith("googlemail.com"))) {
+ StringBuilder url = new StringBuilder(GTASK_URL).append("a/");
+ int index = mAccount.name.indexOf('@') + 1;
+ String suffix = mAccount.name.substring(index);
+ url.append(suffix + "/");
+ mGetUrl = url.toString() + "ig";
+ mPostUrl = url.toString() + "r/ig";
+
+ if (tryToLoginGtask(activity, authToken)) {
+ mLoggedin = true;
+ }
+ }
+
+ // try to login with google official url
+ if (!mLoggedin) {
+ mGetUrl = GTASK_GET_URL;
+ mPostUrl = GTASK_POST_URL;
+ if (!tryToLoginGtask(activity, authToken)) {
+ return false;
+ }
+ }
+
+ mLoggedin = true;
+ return true;
+ }
+
+ private String loginGoogleAccount(Activity activity, boolean invalidateToken) {
+ String authToken;
+ AccountManager accountManager = AccountManager.get(activity);
+ Account[] accounts = accountManager.getAccountsByType("com.google");
+
+ if (accounts.length == 0) {
+ Log.e(TAG, "there is no available google account");
+ return null;
+ }
+
+ String accountName = NotesPreferenceActivity.getSyncAccountName(activity);
+ Account account = null;
+ for (Account a : accounts) {
+ if (a.name.equals(accountName)) {
+ account = a;
+ break;
+ }
+ }
+ if (account != null) {
+ mAccount = account;
+ } else {
+ Log.e(TAG, "unable to get an account with the same name in the settings");
+ return null;
+ }
+
+ // get the token now
+ AccountManagerFuture accountManagerFuture = accountManager.getAuthToken(account,
+ "goanna_mobile", null, activity, null, null);
+ try {
+ Bundle authTokenBundle = accountManagerFuture.getResult();
+ authToken = authTokenBundle.getString(AccountManager.KEY_AUTHTOKEN);
+ if (invalidateToken) {
+ accountManager.invalidateAuthToken("com.google", authToken);
+ loginGoogleAccount(activity, false);
+ }
+ } catch (Exception e) {
+ Log.e(TAG, "get auth token failed");
+ authToken = null;
+ }
+
+ return authToken;
+ }
+
+ private boolean tryToLoginGtask(Activity activity, String authToken) {
+ if (!loginGtask(authToken)) {
+ // maybe the auth token is out of date, now let's invalidate the
+ // token and try again
+ authToken = loginGoogleAccount(activity, true);
+ if (authToken == null) {
+ Log.e(TAG, "login google account failed");
+ return false;
+ }
+
+ if (!loginGtask(authToken)) {
+ Log.e(TAG, "login gtask failed");
+ return false;
+ }
+ }
+ return true;
+ }
+
+ private boolean loginGtask(String authToken) {
+ int timeoutConnection = 10000;
+ int timeoutSocket = 15000;
+ HttpParams httpParameters = new BasicHttpParams();
+ HttpConnectionParams.setConnectionTimeout(httpParameters, timeoutConnection);
+ HttpConnectionParams.setSoTimeout(httpParameters, timeoutSocket);
+ mHttpClient = new DefaultHttpClient(httpParameters);
+ BasicCookieStore localBasicCookieStore = new BasicCookieStore();
+ mHttpClient.setCookieStore(localBasicCookieStore);
+ HttpProtocolParams.setUseExpectContinue(mHttpClient.getParams(), false);
+
+ // login gtask
+ try {
+ String loginUrl = mGetUrl + "?auth=" + authToken;
+ HttpGet httpGet = new HttpGet(loginUrl);
+ HttpResponse response = null;
+ response = mHttpClient.execute(httpGet);
+
+ // get the cookie now
+ List cookies = mHttpClient.getCookieStore().getCookies();
+ boolean hasAuthCookie = false;
+ for (Cookie cookie : cookies) {
+ if (cookie.getName().contains("GTL")) {
+ hasAuthCookie = true;
+ }
+ }
+ if (!hasAuthCookie) {
+ Log.w(TAG, "it seems that there is no auth cookie");
+ }
+
+ // get the client version
+ String resString = getResponseContent(response.getEntity());
+ String jsBegin = "_setup(";
+ String jsEnd = ")}";
+ int begin = resString.indexOf(jsBegin);
+ int end = resString.lastIndexOf(jsEnd);
+ String jsString = null;
+ if (begin != -1 && end != -1 && begin < end) {
+ jsString = resString.substring(begin + jsBegin.length(), end);
+ }
+ JSONObject js = new JSONObject(jsString);
+ mClientVersion = js.getLong("v");
+ } catch (JSONException e) {
+ Log.e(TAG, e.toString());
+ e.printStackTrace();
+ return false;
+ } catch (Exception e) {
+ // simply catch all exceptions
+ Log.e(TAG, "httpget gtask_url failed");
+ return false;
+ }
+
+ return true;
+ }
+
+ private int getActionId() {
+ return mActionId++;
+ }
+
+ private HttpPost createHttpPost() {
+ HttpPost httpPost = new HttpPost(mPostUrl);
+ httpPost.setHeader("Content-Type", "application/x-www-form-urlencoded;charset=utf-8");
+ httpPost.setHeader("AT", "1");
+ return httpPost;
+ }
+
+ private String getResponseContent(HttpEntity entity) throws IOException {
+ String contentEncoding = null;
+ if (entity.getContentEncoding() != null) {
+ contentEncoding = entity.getContentEncoding().getValue();
+ Log.d(TAG, "encoding: " + contentEncoding);
+ }
+
+ InputStream input = entity.getContent();
+ if (contentEncoding != null && contentEncoding.equalsIgnoreCase("gzip")) {
+ input = new GZIPInputStream(entity.getContent());
+ } else if (contentEncoding != null && contentEncoding.equalsIgnoreCase("deflate")) {
+ Inflater inflater = new Inflater(true);
+ input = new InflaterInputStream(entity.getContent(), inflater);
+ }
+
+ try {
+ InputStreamReader isr = new InputStreamReader(input);
+ BufferedReader br = new BufferedReader(isr);
+ StringBuilder sb = new StringBuilder();
+
+ while (true) {
+ String buff = br.readLine();
+ if (buff == null) {
+ return sb.toString();
+ }
+ sb = sb.append(buff);
+ }
+ } finally {
+ input.close();
+ }
+ }
+
+ private JSONObject postRequest(JSONObject js) throws NetworkFailureException {
+ if (!mLoggedin) {
+ Log.e(TAG, "please login first");
+ throw new ActionFailureException("not logged in");
+ }
+
+ HttpPost httpPost = createHttpPost();
+ try {
+ LinkedList list = new LinkedList();
+ list.add(new BasicNameValuePair("r", js.toString()));
+ UrlEncodedFormEntity entity = new UrlEncodedFormEntity(list, "UTF-8");
+ httpPost.setEntity(entity);
+
+ // execute the post
+ HttpResponse response = mHttpClient.execute(httpPost);
+ String jsString = getResponseContent(response.getEntity());
+ return new JSONObject(jsString);
+
+ } catch (ClientProtocolException e) {
+ Log.e(TAG, e.toString());
+ e.printStackTrace();
+ throw new NetworkFailureException("postRequest failed");
+ } catch (IOException e) {
+ Log.e(TAG, e.toString());
+ e.printStackTrace();
+ throw new NetworkFailureException("postRequest failed");
+ } catch (JSONException e) {
+ Log.e(TAG, e.toString());
+ e.printStackTrace();
+ throw new ActionFailureException("unable to convert response content to jsonobject");
+ } catch (Exception e) {
+ Log.e(TAG, e.toString());
+ e.printStackTrace();
+ throw new ActionFailureException("error occurs when posting request");
+ }
+ }
+
+ public void createTask(Task task) throws NetworkFailureException {
+ commitUpdate();
+ try {
+ JSONObject jsPost = new JSONObject();
+ JSONArray actionList = new JSONArray();
+
+ // action_list
+ actionList.put(task.getCreateAction(getActionId()));
+ jsPost.put(GTaskStringUtils.GTASK_JSON_ACTION_LIST, actionList);
+
+ // client_version
+ jsPost.put(GTaskStringUtils.GTASK_JSON_CLIENT_VERSION, mClientVersion);
+
+ // post
+ JSONObject jsResponse = postRequest(jsPost);
+ JSONObject jsResult = (JSONObject) jsResponse.getJSONArray(
+ GTaskStringUtils.GTASK_JSON_RESULTS).get(0);
+ task.setGid(jsResult.getString(GTaskStringUtils.GTASK_JSON_NEW_ID));
+
+ } catch (JSONException e) {
+ Log.e(TAG, e.toString());
+ e.printStackTrace();
+ throw new ActionFailureException("create task: handing jsonobject failed");
+ }
+ }
+
+ public void createTaskList(TaskList tasklist) throws NetworkFailureException {
+ commitUpdate();
+ try {
+ JSONObject jsPost = new JSONObject();
+ JSONArray actionList = new JSONArray();
+
+ // action_list
+ actionList.put(tasklist.getCreateAction(getActionId()));
+ jsPost.put(GTaskStringUtils.GTASK_JSON_ACTION_LIST, actionList);
+
+ // client version
+ jsPost.put(GTaskStringUtils.GTASK_JSON_CLIENT_VERSION, mClientVersion);
+
+ // post
+ JSONObject jsResponse = postRequest(jsPost);
+ JSONObject jsResult = (JSONObject) jsResponse.getJSONArray(
+ GTaskStringUtils.GTASK_JSON_RESULTS).get(0);
+ tasklist.setGid(jsResult.getString(GTaskStringUtils.GTASK_JSON_NEW_ID));
+
+ } catch (JSONException e) {
+ Log.e(TAG, e.toString());
+ e.printStackTrace();
+ throw new ActionFailureException("create tasklist: handing jsonobject failed");
+ }
+ }
+
+ public void commitUpdate() throws NetworkFailureException {
+ if (mUpdateArray != null) {
+ try {
+ JSONObject jsPost = new JSONObject();
+
+ // action_list
+ jsPost.put(GTaskStringUtils.GTASK_JSON_ACTION_LIST, mUpdateArray);
+
+ // client_version
+ jsPost.put(GTaskStringUtils.GTASK_JSON_CLIENT_VERSION, mClientVersion);
+
+ postRequest(jsPost);
+ mUpdateArray = null;
+ } catch (JSONException e) {
+ Log.e(TAG, e.toString());
+ e.printStackTrace();
+ throw new ActionFailureException("commit update: handing jsonobject failed");
+ }
+ }
+ }
+
+ public void addUpdateNode(Node node) throws NetworkFailureException {
+ if (node != null) {
+ // too many update items may result in an error
+ // set max to 10 items
+ if (mUpdateArray != null && mUpdateArray.length() > 10) {
+ commitUpdate();
+ }
+
+ if (mUpdateArray == null)
+ mUpdateArray = new JSONArray();
+ mUpdateArray.put(node.getUpdateAction(getActionId()));
+ }
+ }
+
+ public void moveTask(Task task, TaskList preParent, TaskList curParent)
+ throws NetworkFailureException {
+ commitUpdate();
+ try {
+ JSONObject jsPost = new JSONObject();
+ JSONArray actionList = new JSONArray();
+ JSONObject action = new JSONObject();
+
+ // action_list
+ action.put(GTaskStringUtils.GTASK_JSON_ACTION_TYPE,
+ GTaskStringUtils.GTASK_JSON_ACTION_TYPE_MOVE);
+ action.put(GTaskStringUtils.GTASK_JSON_ACTION_ID, getActionId());
+ action.put(GTaskStringUtils.GTASK_JSON_ID, task.getGid());
+ if (preParent == curParent && task.getPriorSibling() != null) {
+ // put prioring_sibing_id only if moving within the tasklist and
+ // it is not the first one
+ action.put(GTaskStringUtils.GTASK_JSON_PRIOR_SIBLING_ID, task.getPriorSibling());
+ }
+ action.put(GTaskStringUtils.GTASK_JSON_SOURCE_LIST, preParent.getGid());
+ action.put(GTaskStringUtils.GTASK_JSON_DEST_PARENT, curParent.getGid());
+ if (preParent != curParent) {
+ // put the dest_list only if moving between tasklists
+ action.put(GTaskStringUtils.GTASK_JSON_DEST_LIST, curParent.getGid());
+ }
+ actionList.put(action);
+ jsPost.put(GTaskStringUtils.GTASK_JSON_ACTION_LIST, actionList);
+
+ // client_version
+ jsPost.put(GTaskStringUtils.GTASK_JSON_CLIENT_VERSION, mClientVersion);
+
+ postRequest(jsPost);
+
+ } catch (JSONException e) {
+ Log.e(TAG, e.toString());
+ e.printStackTrace();
+ throw new ActionFailureException("move task: handing jsonobject failed");
+ }
+ }
+
+ public void deleteNode(Node node) throws NetworkFailureException {
+ commitUpdate();
+ try {
+ JSONObject jsPost = new JSONObject();
+ JSONArray actionList = new JSONArray();
+
+ // action_list
+ node.setDeleted(true);
+ actionList.put(node.getUpdateAction(getActionId()));
+ jsPost.put(GTaskStringUtils.GTASK_JSON_ACTION_LIST, actionList);
+
+ // client_version
+ jsPost.put(GTaskStringUtils.GTASK_JSON_CLIENT_VERSION, mClientVersion);
+
+ postRequest(jsPost);
+ mUpdateArray = null;
+ } catch (JSONException e) {
+ Log.e(TAG, e.toString());
+ e.printStackTrace();
+ throw new ActionFailureException("delete node: handing jsonobject failed");
+ }
+ }
+
+ public JSONArray getTaskLists() throws NetworkFailureException {
+ if (!mLoggedin) {
+ Log.e(TAG, "please login first");
+ throw new ActionFailureException("not logged in");
+ }
+
+ try {
+ HttpGet httpGet = new HttpGet(mGetUrl);
+ HttpResponse response = null;
+ response = mHttpClient.execute(httpGet);
+
+ // get the task list
+ String resString = getResponseContent(response.getEntity());
+ String jsBegin = "_setup(";
+ String jsEnd = ")}";
+ int begin = resString.indexOf(jsBegin);
+ int end = resString.lastIndexOf(jsEnd);
+ String jsString = null;
+ if (begin != -1 && end != -1 && begin < end) {
+ jsString = resString.substring(begin + jsBegin.length(), end);
+ }
+ JSONObject js = new JSONObject(jsString);
+ return js.getJSONObject("t").getJSONArray(GTaskStringUtils.GTASK_JSON_LISTS);
+ } catch (ClientProtocolException e) {
+ Log.e(TAG, e.toString());
+ e.printStackTrace();
+ throw new NetworkFailureException("gettasklists: httpget failed");
+ } catch (IOException e) {
+ Log.e(TAG, e.toString());
+ e.printStackTrace();
+ throw new NetworkFailureException("gettasklists: httpget failed");
+ } catch (JSONException e) {
+ Log.e(TAG, e.toString());
+ e.printStackTrace();
+ throw new ActionFailureException("get task lists: handing jasonobject failed");
+ }
+ }
+
+ public JSONArray getTaskList(String listGid) throws NetworkFailureException {
+ commitUpdate();
+ try {
+ JSONObject jsPost = new JSONObject();
+ JSONArray actionList = new JSONArray();
+ JSONObject action = new JSONObject();
+
+ // action_list
+ action.put(GTaskStringUtils.GTASK_JSON_ACTION_TYPE,
+ GTaskStringUtils.GTASK_JSON_ACTION_TYPE_GETALL);
+ action.put(GTaskStringUtils.GTASK_JSON_ACTION_ID, getActionId());
+ action.put(GTaskStringUtils.GTASK_JSON_LIST_ID, listGid);
+ action.put(GTaskStringUtils.GTASK_JSON_GET_DELETED, false);
+ actionList.put(action);
+ jsPost.put(GTaskStringUtils.GTASK_JSON_ACTION_LIST, actionList);
+
+ // client_version
+ jsPost.put(GTaskStringUtils.GTASK_JSON_CLIENT_VERSION, mClientVersion);
+
+ JSONObject jsResponse = postRequest(jsPost);
+ return jsResponse.getJSONArray(GTaskStringUtils.GTASK_JSON_TASKS);
+ } catch (JSONException e) {
+ Log.e(TAG, e.toString());
+ e.printStackTrace();
+ throw new ActionFailureException("get task list: handing jsonobject failed");
+ }
+ }
+
+ public Account getSyncAccount() {
+ return mAccount;
+ }
+
+ public void resetUpdateArray() {
+ mUpdateArray = null;
+ }
+}
diff --git a/src/src/Notes-master/src/net/micode/notes/gtask/remote/GTaskManager.java b/src/src/Notes-master/src/net/micode/notes/gtask/remote/GTaskManager.java
new file mode 100644
index 0000000..d2b4082
--- /dev/null
+++ b/src/src/Notes-master/src/net/micode/notes/gtask/remote/GTaskManager.java
@@ -0,0 +1,800 @@
+/*
+ * Copyright (c) 2010-2011, The MiCode Open Source Community (www.micode.net)
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+
+package net.micode.notes.gtask.remote;
+
+import android.app.Activity;
+import android.content.ContentResolver;
+import android.content.ContentUris;
+import android.content.ContentValues;
+import android.content.Context;
+import android.database.Cursor;
+import android.util.Log;
+
+import net.micode.notes.R;
+import net.micode.notes.data.Notes;
+import net.micode.notes.data.Notes.DataColumns;
+import net.micode.notes.data.Notes.NoteColumns;
+import net.micode.notes.gtask.data.MetaData;
+import net.micode.notes.gtask.data.Node;
+import net.micode.notes.gtask.data.SqlNote;
+import net.micode.notes.gtask.data.Task;
+import net.micode.notes.gtask.data.TaskList;
+import net.micode.notes.gtask.exception.ActionFailureException;
+import net.micode.notes.gtask.exception.NetworkFailureException;
+import net.micode.notes.tool.DataUtils;
+import net.micode.notes.tool.GTaskStringUtils;
+
+import org.json.JSONArray;
+import org.json.JSONException;
+import org.json.JSONObject;
+
+import java.util.HashMap;
+import java.util.HashSet;
+import java.util.Iterator;
+import java.util.Map;
+
+
+public class GTaskManager {
+ private static final String TAG = GTaskManager.class.getSimpleName();
+
+ public static final int STATE_SUCCESS = 0;
+
+ public static final int STATE_NETWORK_ERROR = 1;
+
+ public static final int STATE_INTERNAL_ERROR = 2;
+
+ public static final int STATE_SYNC_IN_PROGRESS = 3;
+
+ public static final int STATE_SYNC_CANCELLED = 4;
+
+ private static GTaskManager mInstance = null;
+
+ private Activity mActivity;
+
+ private Context mContext;
+
+ private ContentResolver mContentResolver;
+
+ private boolean mSyncing;
+
+ private boolean mCancelled;
+
+ private HashMap mGTaskListHashMap;
+
+ private HashMap mGTaskHashMap;
+
+ private HashMap mMetaHashMap;
+
+ private TaskList mMetaList;
+
+ private HashSet mLocalDeleteIdMap;
+
+ private HashMap mGidToNid;
+
+ private HashMap mNidToGid;
+
+ private GTaskManager() {
+ mSyncing = false;
+ mCancelled = false;
+ mGTaskListHashMap = new HashMap();
+ mGTaskHashMap = new HashMap();
+ mMetaHashMap = new HashMap();
+ mMetaList = null;
+ mLocalDeleteIdMap = new HashSet();
+ mGidToNid = new HashMap();
+ mNidToGid = new HashMap();
+ }
+
+ public static synchronized GTaskManager getInstance() {
+ if (mInstance == null) {
+ mInstance = new GTaskManager();
+ }
+ return mInstance;
+ }
+
+ public synchronized void setActivityContext(Activity activity) {
+ // used for getting authtoken
+ mActivity = activity;
+ }
+
+ public int sync(Context context, GTaskASyncTask asyncTask) {
+ if (mSyncing) {
+ Log.d(TAG, "Sync is in progress");
+ return STATE_SYNC_IN_PROGRESS;
+ }
+ mContext = context;
+ mContentResolver = mContext.getContentResolver();
+ mSyncing = true;
+ mCancelled = false;
+ mGTaskListHashMap.clear();
+ mGTaskHashMap.clear();
+ mMetaHashMap.clear();
+ mLocalDeleteIdMap.clear();
+ mGidToNid.clear();
+ mNidToGid.clear();
+
+ try {
+ GTaskClient client = GTaskClient.getInstance();
+ client.resetUpdateArray();
+
+ // login google task
+ if (!mCancelled) {
+ if (!client.login(mActivity)) {
+ throw new NetworkFailureException("login google task failed");
+ }
+ }
+
+ // get the task list from google
+ asyncTask.publishProgess(mContext.getString(R.string.sync_progress_init_list));
+ initGTaskList();
+
+ // do content sync work
+ asyncTask.publishProgess(mContext.getString(R.string.sync_progress_syncing));
+ syncContent();
+ } catch (NetworkFailureException e) {
+ Log.e(TAG, e.toString());
+ return STATE_NETWORK_ERROR;
+ } catch (ActionFailureException e) {
+ Log.e(TAG, e.toString());
+ return STATE_INTERNAL_ERROR;
+ } catch (Exception e) {
+ Log.e(TAG, e.toString());
+ e.printStackTrace();
+ return STATE_INTERNAL_ERROR;
+ } finally {
+ mGTaskListHashMap.clear();
+ mGTaskHashMap.clear();
+ mMetaHashMap.clear();
+ mLocalDeleteIdMap.clear();
+ mGidToNid.clear();
+ mNidToGid.clear();
+ mSyncing = false;
+ }
+
+ return mCancelled ? STATE_SYNC_CANCELLED : STATE_SUCCESS;
+ }
+
+ private void initGTaskList() throws NetworkFailureException {
+ if (mCancelled)
+ return;
+ GTaskClient client = GTaskClient.getInstance();
+ try {
+ JSONArray jsTaskLists = client.getTaskLists();
+
+ // init meta list first
+ mMetaList = null;
+ for (int i = 0; i < jsTaskLists.length(); i++) {
+ JSONObject object = jsTaskLists.getJSONObject(i);
+ String gid = object.getString(GTaskStringUtils.GTASK_JSON_ID);
+ String name = object.getString(GTaskStringUtils.GTASK_JSON_NAME);
+
+ if (name
+ .equals(GTaskStringUtils.MIUI_FOLDER_PREFFIX + GTaskStringUtils.FOLDER_META)) {
+ mMetaList = new TaskList();
+ mMetaList.setContentByRemoteJSON(object);
+
+ // load meta data
+ JSONArray jsMetas = client.getTaskList(gid);
+ for (int j = 0; j < jsMetas.length(); j++) {
+ object = (JSONObject) jsMetas.getJSONObject(j);
+ MetaData metaData = new MetaData();
+ metaData.setContentByRemoteJSON(object);
+ if (metaData.isWorthSaving()) {
+ mMetaList.addChildTask(metaData);
+ if (metaData.getGid() != null) {
+ mMetaHashMap.put(metaData.getRelatedGid(), metaData);
+ }
+ }
+ }
+ }
+ }
+
+ // create meta list if not existed
+ if (mMetaList == null) {
+ mMetaList = new TaskList();
+ mMetaList.setName(GTaskStringUtils.MIUI_FOLDER_PREFFIX
+ + GTaskStringUtils.FOLDER_META);
+ GTaskClient.getInstance().createTaskList(mMetaList);
+ }
+
+ // init task list
+ for (int i = 0; i < jsTaskLists.length(); i++) {
+ JSONObject object = jsTaskLists.getJSONObject(i);
+ String gid = object.getString(GTaskStringUtils.GTASK_JSON_ID);
+ String name = object.getString(GTaskStringUtils.GTASK_JSON_NAME);
+
+ if (name.startsWith(GTaskStringUtils.MIUI_FOLDER_PREFFIX)
+ && !name.equals(GTaskStringUtils.MIUI_FOLDER_PREFFIX
+ + GTaskStringUtils.FOLDER_META)) {
+ TaskList tasklist = new TaskList();
+ tasklist.setContentByRemoteJSON(object);
+ mGTaskListHashMap.put(gid, tasklist);
+ mGTaskHashMap.put(gid, tasklist);
+
+ // load tasks
+ JSONArray jsTasks = client.getTaskList(gid);
+ for (int j = 0; j < jsTasks.length(); j++) {
+ object = (JSONObject) jsTasks.getJSONObject(j);
+ gid = object.getString(GTaskStringUtils.GTASK_JSON_ID);
+ Task task = new Task();
+ task.setContentByRemoteJSON(object);
+ if (task.isWorthSaving()) {
+ task.setMetaInfo(mMetaHashMap.get(gid));
+ tasklist.addChildTask(task);
+ mGTaskHashMap.put(gid, task);
+ }
+ }
+ }
+ }
+ } catch (JSONException e) {
+ Log.e(TAG, e.toString());
+ e.printStackTrace();
+ throw new ActionFailureException("initGTaskList: handing JSONObject failed");
+ }
+ }
+
+ private void syncContent() throws NetworkFailureException {
+ int syncType;
+ Cursor c = null;
+ String gid;
+ Node node;
+
+ mLocalDeleteIdMap.clear();
+
+ if (mCancelled) {
+ return;
+ }
+
+ // for local deleted note
+ try {
+ c = mContentResolver.query(Notes.CONTENT_NOTE_URI, SqlNote.PROJECTION_NOTE,
+ "(type<>? AND parent_id=?)", new String[] {
+ String.valueOf(Notes.TYPE_SYSTEM), String.valueOf(Notes.ID_TRASH_FOLER)
+ }, null);
+ if (c != null) {
+ while (c.moveToNext()) {
+ gid = c.getString(SqlNote.GTASK_ID_COLUMN);
+ node = mGTaskHashMap.get(gid);
+ if (node != null) {
+ mGTaskHashMap.remove(gid);
+ doContentSync(Node.SYNC_ACTION_DEL_REMOTE, node, c);
+ }
+
+ mLocalDeleteIdMap.add(c.getLong(SqlNote.ID_COLUMN));
+ }
+ } else {
+ Log.w(TAG, "failed to query trash folder");
+ }
+ } finally {
+ if (c != null) {
+ c.close();
+ c = null;
+ }
+ }
+
+ // sync folder first
+ syncFolder();
+
+ // for note existing in database
+ try {
+ c = mContentResolver.query(Notes.CONTENT_NOTE_URI, SqlNote.PROJECTION_NOTE,
+ "(type=? AND parent_id<>?)", new String[] {
+ String.valueOf(Notes.TYPE_NOTE), String.valueOf(Notes.ID_TRASH_FOLER)
+ }, NoteColumns.TYPE + " DESC");
+ if (c != null) {
+ while (c.moveToNext()) {
+ gid = c.getString(SqlNote.GTASK_ID_COLUMN);
+ node = mGTaskHashMap.get(gid);
+ if (node != null) {
+ mGTaskHashMap.remove(gid);
+ mGidToNid.put(gid, c.getLong(SqlNote.ID_COLUMN));
+ mNidToGid.put(c.getLong(SqlNote.ID_COLUMN), gid);
+ syncType = node.getSyncAction(c);
+ } else {
+ if (c.getString(SqlNote.GTASK_ID_COLUMN).trim().length() == 0) {
+ // local add
+ syncType = Node.SYNC_ACTION_ADD_REMOTE;
+ } else {
+ // remote delete
+ syncType = Node.SYNC_ACTION_DEL_LOCAL;
+ }
+ }
+ doContentSync(syncType, node, c);
+ }
+ } else {
+ Log.w(TAG, "failed to query existing note in database");
+ }
+
+ } finally {
+ if (c != null) {
+ c.close();
+ c = null;
+ }
+ }
+
+ // go through remaining items
+ Iterator> iter = mGTaskHashMap.entrySet().iterator();
+ while (iter.hasNext()) {
+ Map.Entry entry = iter.next();
+ node = entry.getValue();
+ doContentSync(Node.SYNC_ACTION_ADD_LOCAL, node, null);
+ }
+
+ // mCancelled can be set by another thread, so we neet to check one by
+ // one
+ // clear local delete table
+ if (!mCancelled) {
+ if (!DataUtils.batchDeleteNotes(mContentResolver, mLocalDeleteIdMap)) {
+ throw new ActionFailureException("failed to batch-delete local deleted notes");
+ }
+ }
+
+ // refresh local sync id
+ if (!mCancelled) {
+ GTaskClient.getInstance().commitUpdate();
+ refreshLocalSyncId();
+ }
+
+ }
+
+ private void syncFolder() throws NetworkFailureException {
+ Cursor c = null;
+ String gid;
+ Node node;
+ int syncType;
+
+ if (mCancelled) {
+ return;
+ }
+
+ // for root folder
+ try {
+ c = mContentResolver.query(ContentUris.withAppendedId(Notes.CONTENT_NOTE_URI,
+ Notes.ID_ROOT_FOLDER), SqlNote.PROJECTION_NOTE, null, null, null);
+ if (c != null) {
+ c.moveToNext();
+ gid = c.getString(SqlNote.GTASK_ID_COLUMN);
+ node = mGTaskHashMap.get(gid);
+ if (node != null) {
+ mGTaskHashMap.remove(gid);
+ mGidToNid.put(gid, (long) Notes.ID_ROOT_FOLDER);
+ mNidToGid.put((long) Notes.ID_ROOT_FOLDER, gid);
+ // for system folder, only update remote name if necessary
+ if (!node.getName().equals(
+ GTaskStringUtils.MIUI_FOLDER_PREFFIX + GTaskStringUtils.FOLDER_DEFAULT))
+ doContentSync(Node.SYNC_ACTION_UPDATE_REMOTE, node, c);
+ } else {
+ doContentSync(Node.SYNC_ACTION_ADD_REMOTE, node, c);
+ }
+ } else {
+ Log.w(TAG, "failed to query root folder");
+ }
+ } finally {
+ if (c != null) {
+ c.close();
+ c = null;
+ }
+ }
+
+ // for call-note folder
+ try {
+ c = mContentResolver.query(Notes.CONTENT_NOTE_URI, SqlNote.PROJECTION_NOTE, "(_id=?)",
+ new String[] {
+ String.valueOf(Notes.ID_CALL_RECORD_FOLDER)
+ }, null);
+ if (c != null) {
+ if (c.moveToNext()) {
+ gid = c.getString(SqlNote.GTASK_ID_COLUMN);
+ node = mGTaskHashMap.get(gid);
+ if (node != null) {
+ mGTaskHashMap.remove(gid);
+ mGidToNid.put(gid, (long) Notes.ID_CALL_RECORD_FOLDER);
+ mNidToGid.put((long) Notes.ID_CALL_RECORD_FOLDER, gid);
+ // for system folder, only update remote name if
+ // necessary
+ if (!node.getName().equals(
+ GTaskStringUtils.MIUI_FOLDER_PREFFIX
+ + GTaskStringUtils.FOLDER_CALL_NOTE))
+ doContentSync(Node.SYNC_ACTION_UPDATE_REMOTE, node, c);
+ } else {
+ doContentSync(Node.SYNC_ACTION_ADD_REMOTE, node, c);
+ }
+ }
+ } else {
+ Log.w(TAG, "failed to query call note folder");
+ }
+ } finally {
+ if (c != null) {
+ c.close();
+ c = null;
+ }
+ }
+
+ // for local existing folders
+ try {
+ c = mContentResolver.query(Notes.CONTENT_NOTE_URI, SqlNote.PROJECTION_NOTE,
+ "(type=? AND parent_id<>?)", new String[] {
+ String.valueOf(Notes.TYPE_FOLDER), String.valueOf(Notes.ID_TRASH_FOLER)
+ }, NoteColumns.TYPE + " DESC");
+ if (c != null) {
+ while (c.moveToNext()) {
+ gid = c.getString(SqlNote.GTASK_ID_COLUMN);
+ node = mGTaskHashMap.get(gid);
+ if (node != null) {
+ mGTaskHashMap.remove(gid);
+ mGidToNid.put(gid, c.getLong(SqlNote.ID_COLUMN));
+ mNidToGid.put(c.getLong(SqlNote.ID_COLUMN), gid);
+ syncType = node.getSyncAction(c);
+ } else {
+ if (c.getString(SqlNote.GTASK_ID_COLUMN).trim().length() == 0) {
+ // local add
+ syncType = Node.SYNC_ACTION_ADD_REMOTE;
+ } else {
+ // remote delete
+ syncType = Node.SYNC_ACTION_DEL_LOCAL;
+ }
+ }
+ doContentSync(syncType, node, c);
+ }
+ } else {
+ Log.w(TAG, "failed to query existing folder");
+ }
+ } finally {
+ if (c != null) {
+ c.close();
+ c = null;
+ }
+ }
+
+ // for remote add folders
+ Iterator> iter = mGTaskListHashMap.entrySet().iterator();
+ while (iter.hasNext()) {
+ Map.Entry entry = iter.next();
+ gid = entry.getKey();
+ node = entry.getValue();
+ if (mGTaskHashMap.containsKey(gid)) {
+ mGTaskHashMap.remove(gid);
+ doContentSync(Node.SYNC_ACTION_ADD_LOCAL, node, null);
+ }
+ }
+
+ if (!mCancelled)
+ GTaskClient.getInstance().commitUpdate();
+ }
+
+ private void doContentSync(int syncType, Node node, Cursor c) throws NetworkFailureException {
+ if (mCancelled) {
+ return;
+ }
+
+ MetaData meta;
+ switch (syncType) {
+ case Node.SYNC_ACTION_ADD_LOCAL:
+ addLocalNode(node);
+ break;
+ case Node.SYNC_ACTION_ADD_REMOTE:
+ addRemoteNode(node, c);
+ break;
+ case Node.SYNC_ACTION_DEL_LOCAL:
+ meta = mMetaHashMap.get(c.getString(SqlNote.GTASK_ID_COLUMN));
+ if (meta != null) {
+ GTaskClient.getInstance().deleteNode(meta);
+ }
+ mLocalDeleteIdMap.add(c.getLong(SqlNote.ID_COLUMN));
+ break;
+ case Node.SYNC_ACTION_DEL_REMOTE:
+ meta = mMetaHashMap.get(node.getGid());
+ if (meta != null) {
+ GTaskClient.getInstance().deleteNode(meta);
+ }
+ GTaskClient.getInstance().deleteNode(node);
+ break;
+ case Node.SYNC_ACTION_UPDATE_LOCAL:
+ updateLocalNode(node, c);
+ break;
+ case Node.SYNC_ACTION_UPDATE_REMOTE:
+ updateRemoteNode(node, c);
+ break;
+ case Node.SYNC_ACTION_UPDATE_CONFLICT:
+ // merging both modifications maybe a good idea
+ // right now just use local update simply
+ updateRemoteNode(node, c);
+ break;
+ case Node.SYNC_ACTION_NONE:
+ break;
+ case Node.SYNC_ACTION_ERROR:
+ default:
+ throw new ActionFailureException("unkown sync action type");
+ }
+ }
+
+ private void addLocalNode(Node node) throws NetworkFailureException {
+ if (mCancelled) {
+ return;
+ }
+
+ SqlNote sqlNote;
+ if (node instanceof TaskList) {
+ if (node.getName().equals(
+ GTaskStringUtils.MIUI_FOLDER_PREFFIX + GTaskStringUtils.FOLDER_DEFAULT)) {
+ sqlNote = new SqlNote(mContext, Notes.ID_ROOT_FOLDER);
+ } else if (node.getName().equals(
+ GTaskStringUtils.MIUI_FOLDER_PREFFIX + GTaskStringUtils.FOLDER_CALL_NOTE)) {
+ sqlNote = new SqlNote(mContext, Notes.ID_CALL_RECORD_FOLDER);
+ } else {
+ sqlNote = new SqlNote(mContext);
+ sqlNote.setContent(node.getLocalJSONFromContent());
+ sqlNote.setParentId(Notes.ID_ROOT_FOLDER);
+ }
+ } else {
+ sqlNote = new SqlNote(mContext);
+ JSONObject js = node.getLocalJSONFromContent();
+ try {
+ if (js.has(GTaskStringUtils.META_HEAD_NOTE)) {
+ JSONObject note = js.getJSONObject(GTaskStringUtils.META_HEAD_NOTE);
+ if (note.has(NoteColumns.ID)) {
+ long id = note.getLong(NoteColumns.ID);
+ if (DataUtils.existInNoteDatabase(mContentResolver, id)) {
+ // the id is not available, have to create a new one
+ note.remove(NoteColumns.ID);
+ }
+ }
+ }
+
+ if (js.has(GTaskStringUtils.META_HEAD_DATA)) {
+ JSONArray dataArray = js.getJSONArray(GTaskStringUtils.META_HEAD_DATA);
+ for (int i = 0; i < dataArray.length(); i++) {
+ JSONObject data = dataArray.getJSONObject(i);
+ if (data.has(DataColumns.ID)) {
+ long dataId = data.getLong(DataColumns.ID);
+ if (DataUtils.existInDataDatabase(mContentResolver, dataId)) {
+ // the data id is not available, have to create
+ // a new one
+ data.remove(DataColumns.ID);
+ }
+ }
+ }
+
+ }
+ } catch (JSONException e) {
+ Log.w(TAG, e.toString());
+ e.printStackTrace();
+ }
+ sqlNote.setContent(js);
+
+ Long parentId = mGidToNid.get(((Task) node).getParent().getGid());
+ if (parentId == null) {
+ Log.e(TAG, "cannot find task's parent id locally");
+ throw new ActionFailureException("cannot add local node");
+ }
+ sqlNote.setParentId(parentId.longValue());
+ }
+
+ // create the local node
+ sqlNote.setGtaskId(node.getGid());
+ sqlNote.commit(false);
+
+ // update gid-nid mapping
+ mGidToNid.put(node.getGid(), sqlNote.getId());
+ mNidToGid.put(sqlNote.getId(), node.getGid());
+
+ // update meta
+ updateRemoteMeta(node.getGid(), sqlNote);
+ }
+
+ private void updateLocalNode(Node node, Cursor c) throws NetworkFailureException {
+ if (mCancelled) {
+ return;
+ }
+
+ SqlNote sqlNote;
+ // update the note locally
+ sqlNote = new SqlNote(mContext, c);
+ sqlNote.setContent(node.getLocalJSONFromContent());
+
+ Long parentId = (node instanceof Task) ? mGidToNid.get(((Task) node).getParent().getGid())
+ : new Long(Notes.ID_ROOT_FOLDER);
+ if (parentId == null) {
+ Log.e(TAG, "cannot find task's parent id locally");
+ throw new ActionFailureException("cannot update local node");
+ }
+ sqlNote.setParentId(parentId.longValue());
+ sqlNote.commit(true);
+
+ // update meta info
+ updateRemoteMeta(node.getGid(), sqlNote);
+ }
+
+ private void addRemoteNode(Node node, Cursor c) throws NetworkFailureException {
+ if (mCancelled) {
+ return;
+ }
+
+ SqlNote sqlNote = new SqlNote(mContext, c);
+ Node n;
+
+ // update remotely
+ if (sqlNote.isNoteType()) {
+ Task task = new Task();
+ task.setContentByLocalJSON(sqlNote.getContent());
+
+ String parentGid = mNidToGid.get(sqlNote.getParentId());
+ if (parentGid == null) {
+ Log.e(TAG, "cannot find task's parent tasklist");
+ throw new ActionFailureException("cannot add remote task");
+ }
+ mGTaskListHashMap.get(parentGid).addChildTask(task);
+
+ GTaskClient.getInstance().createTask(task);
+ n = (Node) task;
+
+ // add meta
+ updateRemoteMeta(task.getGid(), sqlNote);
+ } else {
+ TaskList tasklist = null;
+
+ // we need to skip folder if it has already existed
+ String folderName = GTaskStringUtils.MIUI_FOLDER_PREFFIX;
+ if (sqlNote.getId() == Notes.ID_ROOT_FOLDER)
+ folderName += GTaskStringUtils.FOLDER_DEFAULT;
+ else if (sqlNote.getId() == Notes.ID_CALL_RECORD_FOLDER)
+ folderName += GTaskStringUtils.FOLDER_CALL_NOTE;
+ else
+ folderName += sqlNote.getSnippet();
+
+ Iterator> iter = mGTaskListHashMap.entrySet().iterator();
+ while (iter.hasNext()) {
+ Map.Entry entry = iter.next();
+ String gid = entry.getKey();
+ TaskList list = entry.getValue();
+
+ if (list.getName().equals(folderName)) {
+ tasklist = list;
+ if (mGTaskHashMap.containsKey(gid)) {
+ mGTaskHashMap.remove(gid);
+ }
+ break;
+ }
+ }
+
+ // no match we can add now
+ if (tasklist == null) {
+ tasklist = new TaskList();
+ tasklist.setContentByLocalJSON(sqlNote.getContent());
+ GTaskClient.getInstance().createTaskList(tasklist);
+ mGTaskListHashMap.put(tasklist.getGid(), tasklist);
+ }
+ n = (Node) tasklist;
+ }
+
+ // update local note
+ sqlNote.setGtaskId(n.getGid());
+ sqlNote.commit(false);
+ sqlNote.resetLocalModified();
+ sqlNote.commit(true);
+
+ // gid-id mapping
+ mGidToNid.put(n.getGid(), sqlNote.getId());
+ mNidToGid.put(sqlNote.getId(), n.getGid());
+ }
+
+ private void updateRemoteNode(Node node, Cursor c) throws NetworkFailureException {
+ if (mCancelled) {
+ return;
+ }
+
+ SqlNote sqlNote = new SqlNote(mContext, c);
+
+ // update remotely
+ node.setContentByLocalJSON(sqlNote.getContent());
+ GTaskClient.getInstance().addUpdateNode(node);
+
+ // update meta
+ updateRemoteMeta(node.getGid(), sqlNote);
+
+ // move task if necessary
+ if (sqlNote.isNoteType()) {
+ Task task = (Task) node;
+ TaskList preParentList = task.getParent();
+
+ String curParentGid = mNidToGid.get(sqlNote.getParentId());
+ if (curParentGid == null) {
+ Log.e(TAG, "cannot find task's parent tasklist");
+ throw new ActionFailureException("cannot update remote task");
+ }
+ TaskList curParentList = mGTaskListHashMap.get(curParentGid);
+
+ if (preParentList != curParentList) {
+ preParentList.removeChildTask(task);
+ curParentList.addChildTask(task);
+ GTaskClient.getInstance().moveTask(task, preParentList, curParentList);
+ }
+ }
+
+ // clear local modified flag
+ sqlNote.resetLocalModified();
+ sqlNote.commit(true);
+ }
+
+ private void updateRemoteMeta(String gid, SqlNote sqlNote) throws NetworkFailureException {
+ if (sqlNote != null && sqlNote.isNoteType()) {
+ MetaData metaData = mMetaHashMap.get(gid);
+ if (metaData != null) {
+ metaData.setMeta(gid, sqlNote.getContent());
+ GTaskClient.getInstance().addUpdateNode(metaData);
+ } else {
+ metaData = new MetaData();
+ metaData.setMeta(gid, sqlNote.getContent());
+ mMetaList.addChildTask(metaData);
+ mMetaHashMap.put(gid, metaData);
+ GTaskClient.getInstance().createTask(metaData);
+ }
+ }
+ }
+
+ private void refreshLocalSyncId() throws NetworkFailureException {
+ if (mCancelled) {
+ return;
+ }
+
+ // get the latest gtask list
+ mGTaskHashMap.clear();
+ mGTaskListHashMap.clear();
+ mMetaHashMap.clear();
+ initGTaskList();
+
+ Cursor c = null;
+ try {
+ c = mContentResolver.query(Notes.CONTENT_NOTE_URI, SqlNote.PROJECTION_NOTE,
+ "(type<>? AND parent_id<>?)", new String[] {
+ String.valueOf(Notes.TYPE_SYSTEM), String.valueOf(Notes.ID_TRASH_FOLER)
+ }, NoteColumns.TYPE + " DESC");
+ if (c != null) {
+ while (c.moveToNext()) {
+ String gid = c.getString(SqlNote.GTASK_ID_COLUMN);
+ Node node = mGTaskHashMap.get(gid);
+ if (node != null) {
+ mGTaskHashMap.remove(gid);
+ ContentValues values = new ContentValues();
+ values.put(NoteColumns.SYNC_ID, node.getLastModified());
+ mContentResolver.update(ContentUris.withAppendedId(Notes.CONTENT_NOTE_URI,
+ c.getLong(SqlNote.ID_COLUMN)), values, null, null);
+ } else {
+ Log.e(TAG, "something is missed");
+ throw new ActionFailureException(
+ "some local items don't have gid after sync");
+ }
+ }
+ } else {
+ Log.w(TAG, "failed to query local note to refresh sync id");
+ }
+ } finally {
+ if (c != null) {
+ c.close();
+ c = null;
+ }
+ }
+ }
+
+ public String getSyncAccount() {
+ return GTaskClient.getInstance().getSyncAccount().name;
+ }
+
+ public void cancelSync() {
+ mCancelled = true;
+ }
+}
diff --git a/src/src/Notes-master/src/net/micode/notes/gtask/remote/GTaskSyncService.java b/src/src/Notes-master/src/net/micode/notes/gtask/remote/GTaskSyncService.java
new file mode 100644
index 0000000..cca36f7
--- /dev/null
+++ b/src/src/Notes-master/src/net/micode/notes/gtask/remote/GTaskSyncService.java
@@ -0,0 +1,128 @@
+/*
+ * Copyright (c) 2010-2011, The MiCode Open Source Community (www.micode.net)
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+
+package net.micode.notes.gtask.remote;
+
+import android.app.Activity;
+import android.app.Service;
+import android.content.Context;
+import android.content.Intent;
+import android.os.Bundle;
+import android.os.IBinder;
+
+public class GTaskSyncService extends Service {
+ public final static String ACTION_STRING_NAME = "sync_action_type";
+
+ public final static int ACTION_START_SYNC = 0;
+
+ public final static int ACTION_CANCEL_SYNC = 1;
+
+ public final static int ACTION_INVALID = 2;
+
+ public final static String GTASK_SERVICE_BROADCAST_NAME = "net.micode.notes.gtask.remote.gtask_sync_service";
+
+ public final static String GTASK_SERVICE_BROADCAST_IS_SYNCING = "isSyncing";
+
+ public final static String GTASK_SERVICE_BROADCAST_PROGRESS_MSG = "progressMsg";
+
+ private static GTaskASyncTask mSyncTask = null;
+
+ private static String mSyncProgress = "";
+
+ private void startSync() {
+ if (mSyncTask == null) {
+ mSyncTask = new GTaskASyncTask(this, new GTaskASyncTask.OnCompleteListener() {
+ public void onComplete() {
+ mSyncTask = null;
+ sendBroadcast("");
+ stopSelf();
+ }
+ });
+ sendBroadcast("");
+ mSyncTask.execute();
+ }
+ }
+
+ private void cancelSync() {
+ if (mSyncTask != null) {
+ mSyncTask.cancelSync();
+ }
+ }
+
+ @Override
+ public void onCreate() {
+ mSyncTask = null;
+ }
+
+ @Override
+ public int onStartCommand(Intent intent, int flags, int startId) {
+ Bundle bundle = intent.getExtras();
+ if (bundle != null && bundle.containsKey(ACTION_STRING_NAME)) {
+ switch (bundle.getInt(ACTION_STRING_NAME, ACTION_INVALID)) {
+ case ACTION_START_SYNC:
+ startSync();
+ break;
+ case ACTION_CANCEL_SYNC:
+ cancelSync();
+ break;
+ default:
+ break;
+ }
+ return START_STICKY;
+ }
+ return super.onStartCommand(intent, flags, startId);
+ }
+
+ @Override
+ public void onLowMemory() {
+ if (mSyncTask != null) {
+ mSyncTask.cancelSync();
+ }
+ }
+
+ public IBinder onBind(Intent intent) {
+ return null;
+ }
+
+ public void sendBroadcast(String msg) {
+ mSyncProgress = msg;
+ Intent intent = new Intent(GTASK_SERVICE_BROADCAST_NAME);
+ intent.putExtra(GTASK_SERVICE_BROADCAST_IS_SYNCING, mSyncTask != null);
+ intent.putExtra(GTASK_SERVICE_BROADCAST_PROGRESS_MSG, msg);
+ sendBroadcast(intent);
+ }
+
+ public static void startSync(Activity activity) {
+ GTaskManager.getInstance().setActivityContext(activity);
+ Intent intent = new Intent(activity, GTaskSyncService.class);
+ intent.putExtra(GTaskSyncService.ACTION_STRING_NAME, GTaskSyncService.ACTION_START_SYNC);
+ activity.startService(intent);
+ }
+
+ public static void cancelSync(Context context) {
+ Intent intent = new Intent(context, GTaskSyncService.class);
+ intent.putExtra(GTaskSyncService.ACTION_STRING_NAME, GTaskSyncService.ACTION_CANCEL_SYNC);
+ context.startService(intent);
+ }
+
+ public static boolean isSyncing() {
+ return mSyncTask != null;
+ }
+
+ public static String getProgressString() {
+ return mSyncProgress;
+ }
+}
diff --git a/src/src/Notes-master/src/net/micode/notes/model/Note.java b/src/src/Notes-master/src/net/micode/notes/model/Note.java
new file mode 100644
index 0000000..6706cf6
--- /dev/null
+++ b/src/src/Notes-master/src/net/micode/notes/model/Note.java
@@ -0,0 +1,253 @@
+/*
+ * Copyright (c) 2010-2011, The MiCode Open Source Community (www.micode.net)
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+
+package net.micode.notes.model;
+import android.content.ContentProviderOperation;
+import android.content.ContentProviderResult;
+import android.content.ContentUris;
+import android.content.ContentValues;
+import android.content.Context;
+import android.content.OperationApplicationException;
+import android.net.Uri;
+import android.os.RemoteException;
+import android.util.Log;
+
+import net.micode.notes.data.Notes;
+import net.micode.notes.data.Notes.CallNote;
+import net.micode.notes.data.Notes.DataColumns;
+import net.micode.notes.data.Notes.NoteColumns;
+import net.micode.notes.data.Notes.TextNote;
+
+import java.util.ArrayList;
+
+
+public class Note {
+ private ContentValues mNoteDiffValues;
+ private NoteData mNoteData;
+ private static final String TAG = "Note";
+ /**
+ * Create a new note id for adding a new note to databases
+ */
+ public static synchronized long getNewNoteId(Context context, long folderId) {
+ // Create a new note in the database
+ ContentValues values = new ContentValues();
+ long createdTime = System.currentTimeMillis();
+ values.put(NoteColumns.CREATED_DATE, createdTime);
+ values.put(NoteColumns.MODIFIED_DATE, createdTime);
+ values.put(NoteColumns.TYPE, Notes.TYPE_NOTE);
+ values.put(NoteColumns.LOCAL_MODIFIED, 1);
+ values.put(NoteColumns.PARENT_ID, folderId);
+ Uri uri = context.getContentResolver().insert(Notes.CONTENT_NOTE_URI, values);
+
+ long noteId = 0;
+ try {
+ noteId = Long.valueOf(uri.getPathSegments().get(1));
+ } catch (NumberFormatException e) {
+ Log.e(TAG, "Get note id error :" + e.toString());
+ noteId = 0;
+ }
+ if (noteId == -1) {
+ throw new IllegalStateException("Wrong note id:" + noteId);
+ }
+ return noteId;
+ }
+
+ public Note() {
+ mNoteDiffValues = new ContentValues();
+ mNoteData = new NoteData();
+ }
+
+ public void setNoteValue(String key, String value) {
+ mNoteDiffValues.put(key, value);
+ mNoteDiffValues.put(NoteColumns.LOCAL_MODIFIED, 1);
+ mNoteDiffValues.put(NoteColumns.MODIFIED_DATE, System.currentTimeMillis());
+ }
+
+ public void setTextData(String key, String value) {
+ mNoteData.setTextData(key, value);
+ }
+
+ public void setTextDataId(long id) {
+ mNoteData.setTextDataId(id);
+ }
+
+ public long getTextDataId() {
+ return mNoteData.mTextDataId;
+ }
+
+ public void setCallDataId(long id) {
+ mNoteData.setCallDataId(id);
+ }
+
+ public void setCallData(String key, String value) {
+ mNoteData.setCallData(key, value);
+ }
+
+ public boolean isLocalModified() {
+ return mNoteDiffValues.size() > 0 || mNoteData.isLocalModified();
+ }
+
+ public boolean syncNote(Context context, long noteId) {
+ if (noteId <= 0) {
+ throw new IllegalArgumentException("Wrong note id:" + noteId);
+ }
+
+ if (!isLocalModified()) {
+ return true;
+ }
+
+ /**
+ * In theory, once data changed, the note should be updated on {@link NoteColumns#LOCAL_MODIFIED} and
+ * {@link NoteColumns#MODIFIED_DATE}. For data safety, though update note fails, we also update the
+ * note data info
+ */
+ if (context.getContentResolver().update(
+ ContentUris.withAppendedId(Notes.CONTENT_NOTE_URI, noteId), mNoteDiffValues, null,
+ null) == 0) {
+ Log.e(TAG, "Update note error, should not happen");
+ // Do not return, fall through
+ }
+ mNoteDiffValues.clear();
+
+ if (mNoteData.isLocalModified()
+ && (mNoteData.pushIntoContentResolver(context, noteId) == null)) {
+ return false;
+ }
+
+ return true;
+ }
+
+ private class NoteData {
+ private long mTextDataId;
+
+ private ContentValues mTextDataValues;
+
+ private long mCallDataId;
+
+ private ContentValues mCallDataValues;
+
+ private static final String TAG = "NoteData";
+
+ public NoteData() {
+ mTextDataValues = new ContentValues();
+ mCallDataValues = new ContentValues();
+ mTextDataId = 0;
+ mCallDataId = 0;
+ }
+
+ boolean isLocalModified() {
+ return mTextDataValues.size() > 0 || mCallDataValues.size() > 0;
+ }
+
+ void setTextDataId(long id) {
+ if(id <= 0) {
+ throw new IllegalArgumentException("Text data id should larger than 0");
+ }
+ mTextDataId = id;
+ }
+
+ void setCallDataId(long id) {
+ if (id <= 0) {
+ throw new IllegalArgumentException("Call data id should larger than 0");
+ }
+ mCallDataId = id;
+ }
+
+ void setCallData(String key, String value) {
+ mCallDataValues.put(key, value);
+ mNoteDiffValues.put(NoteColumns.LOCAL_MODIFIED, 1);
+ mNoteDiffValues.put(NoteColumns.MODIFIED_DATE, System.currentTimeMillis());
+ }
+
+ void setTextData(String key, String value) {
+ mTextDataValues.put(key, value);
+ mNoteDiffValues.put(NoteColumns.LOCAL_MODIFIED, 1);
+ mNoteDiffValues.put(NoteColumns.MODIFIED_DATE, System.currentTimeMillis());
+ }
+
+ Uri pushIntoContentResolver(Context context, long noteId) {
+ /**
+ * Check for safety
+ */
+ if (noteId <= 0) {
+ throw new IllegalArgumentException("Wrong note id:" + noteId);
+ }
+
+ ArrayList operationList = new ArrayList();
+ ContentProviderOperation.Builder builder = null;
+
+ if(mTextDataValues.size() > 0) {
+ mTextDataValues.put(DataColumns.NOTE_ID, noteId);
+ if (mTextDataId == 0) {
+ mTextDataValues.put(DataColumns.MIME_TYPE, TextNote.CONTENT_ITEM_TYPE);
+ Uri uri = context.getContentResolver().insert(Notes.CONTENT_DATA_URI,
+ mTextDataValues);
+ try {
+ setTextDataId(Long.valueOf(uri.getPathSegments().get(1)));
+ } catch (NumberFormatException e) {
+ Log.e(TAG, "Insert new text data fail with noteId" + noteId);
+ mTextDataValues.clear();
+ return null;
+ }
+ } else {
+ builder = ContentProviderOperation.newUpdate(ContentUris.withAppendedId(
+ Notes.CONTENT_DATA_URI, mTextDataId));
+ builder.withValues(mTextDataValues);
+ operationList.add(builder.build());
+ }
+ mTextDataValues.clear();
+ }
+
+ if(mCallDataValues.size() > 0) {
+ mCallDataValues.put(DataColumns.NOTE_ID, noteId);
+ if (mCallDataId == 0) {
+ mCallDataValues.put(DataColumns.MIME_TYPE, CallNote.CONTENT_ITEM_TYPE);
+ Uri uri = context.getContentResolver().insert(Notes.CONTENT_DATA_URI,
+ mCallDataValues);
+ try {
+ setCallDataId(Long.valueOf(uri.getPathSegments().get(1)));
+ } catch (NumberFormatException e) {
+ Log.e(TAG, "Insert new call data fail with noteId" + noteId);
+ mCallDataValues.clear();
+ return null;
+ }
+ } else {
+ builder = ContentProviderOperation.newUpdate(ContentUris.withAppendedId(
+ Notes.CONTENT_DATA_URI, mCallDataId));
+ builder.withValues(mCallDataValues);
+ operationList.add(builder.build());
+ }
+ mCallDataValues.clear();
+ }
+
+ if (operationList.size() > 0) {
+ try {
+ ContentProviderResult[] results = context.getContentResolver().applyBatch(
+ Notes.AUTHORITY, operationList);
+ return (results == null || results.length == 0 || results[0] == null) ? null
+ : ContentUris.withAppendedId(Notes.CONTENT_NOTE_URI, noteId);
+ } catch (RemoteException e) {
+ Log.e(TAG, String.format("%s: %s", e.toString(), e.getMessage()));
+ return null;
+ } catch (OperationApplicationException e) {
+ Log.e(TAG, String.format("%s: %s", e.toString(), e.getMessage()));
+ return null;
+ }
+ }
+ return null;
+ }
+ }
+}
diff --git a/src/src/Notes-master/src/net/micode/notes/model/WorkingNote.java b/src/src/Notes-master/src/net/micode/notes/model/WorkingNote.java
new file mode 100644
index 0000000..be081e4
--- /dev/null
+++ b/src/src/Notes-master/src/net/micode/notes/model/WorkingNote.java
@@ -0,0 +1,368 @@
+/*
+ * Copyright (c) 2010-2011, The MiCode Open Source Community (www.micode.net)
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+
+package net.micode.notes.model;
+
+import android.appwidget.AppWidgetManager;
+import android.content.ContentUris;
+import android.content.Context;
+import android.database.Cursor;
+import android.text.TextUtils;
+import android.util.Log;
+
+import net.micode.notes.data.Notes;
+import net.micode.notes.data.Notes.CallNote;
+import net.micode.notes.data.Notes.DataColumns;
+import net.micode.notes.data.Notes.DataConstants;
+import net.micode.notes.data.Notes.NoteColumns;
+import net.micode.notes.data.Notes.TextNote;
+import net.micode.notes.tool.ResourceParser.NoteBgResources;
+
+
+public class WorkingNote {
+ // Note for the working note
+ private Note mNote;
+ // Note Id
+ private long mNoteId;
+ // Note content
+ private String mContent;
+ // Note mode
+ private int mMode;
+
+ private long mAlertDate;
+
+ private long mModifiedDate;
+
+ private int mBgColorId;
+
+ private int mWidgetId;
+
+ private int mWidgetType;
+
+ private long mFolderId;
+
+ private Context mContext;
+
+ private static final String TAG = "WorkingNote";
+
+ private boolean mIsDeleted;
+
+ private NoteSettingChangedListener mNoteSettingStatusListener;
+
+ public static final String[] DATA_PROJECTION = new String[] {
+ DataColumns.ID,
+ DataColumns.CONTENT,
+ DataColumns.MIME_TYPE,
+ DataColumns.DATA1,
+ DataColumns.DATA2,
+ DataColumns.DATA3,
+ DataColumns.DATA4,
+ };
+
+ public static final String[] NOTE_PROJECTION = new String[] {
+ NoteColumns.PARENT_ID,
+ NoteColumns.ALERTED_DATE,
+ NoteColumns.BG_COLOR_ID,
+ NoteColumns.WIDGET_ID,
+ NoteColumns.WIDGET_TYPE,
+ NoteColumns.MODIFIED_DATE
+ };
+
+ private static final int DATA_ID_COLUMN = 0;
+
+ private static final int DATA_CONTENT_COLUMN = 1;
+
+ private static final int DATA_MIME_TYPE_COLUMN = 2;
+
+ private static final int DATA_MODE_COLUMN = 3;
+
+ private static final int NOTE_PARENT_ID_COLUMN = 0;
+
+ private static final int NOTE_ALERTED_DATE_COLUMN = 1;
+
+ private static final int NOTE_BG_COLOR_ID_COLUMN = 2;
+
+ private static final int NOTE_WIDGET_ID_COLUMN = 3;
+
+ private static final int NOTE_WIDGET_TYPE_COLUMN = 4;
+
+ private static final int NOTE_MODIFIED_DATE_COLUMN = 5;
+
+ // New note construct
+ private WorkingNote(Context context, long folderId) {
+ mContext = context;
+ mAlertDate = 0;
+ mModifiedDate = System.currentTimeMillis();
+ mFolderId = folderId;
+ mNote = new Note();
+ mNoteId = 0;
+ mIsDeleted = false;
+ mMode = 0;
+ mWidgetType = Notes.TYPE_WIDGET_INVALIDE;
+ }
+
+ // Existing note construct
+ private WorkingNote(Context context, long noteId, long folderId) {
+ mContext = context;
+ mNoteId = noteId;
+ mFolderId = folderId;
+ mIsDeleted = false;
+ mNote = new Note();
+ loadNote();
+ }
+
+ private void loadNote() {
+ Cursor cursor = mContext.getContentResolver().query(
+ ContentUris.withAppendedId(Notes.CONTENT_NOTE_URI, mNoteId), NOTE_PROJECTION, null,
+ null, null);
+
+ if (cursor != null) {
+ if (cursor.moveToFirst()) {
+ mFolderId = cursor.getLong(NOTE_PARENT_ID_COLUMN);
+ mBgColorId = cursor.getInt(NOTE_BG_COLOR_ID_COLUMN);
+ mWidgetId = cursor.getInt(NOTE_WIDGET_ID_COLUMN);
+ mWidgetType = cursor.getInt(NOTE_WIDGET_TYPE_COLUMN);
+ mAlertDate = cursor.getLong(NOTE_ALERTED_DATE_COLUMN);
+ mModifiedDate = cursor.getLong(NOTE_MODIFIED_DATE_COLUMN);
+ }
+ cursor.close();
+ } else {
+ Log.e(TAG, "No note with id:" + mNoteId);
+ throw new IllegalArgumentException("Unable to find note with id " + mNoteId);
+ }
+ loadNoteData();
+ }
+
+ private void loadNoteData() {
+ Cursor cursor = mContext.getContentResolver().query(Notes.CONTENT_DATA_URI, DATA_PROJECTION,
+ DataColumns.NOTE_ID + "=?", new String[] {
+ String.valueOf(mNoteId)
+ }, null);
+
+ if (cursor != null) {
+ if (cursor.moveToFirst()) {
+ do {
+ String type = cursor.getString(DATA_MIME_TYPE_COLUMN);
+ if (DataConstants.NOTE.equals(type)) {
+ mContent = cursor.getString(DATA_CONTENT_COLUMN);
+ mMode = cursor.getInt(DATA_MODE_COLUMN);
+ mNote.setTextDataId(cursor.getLong(DATA_ID_COLUMN));
+ } else if (DataConstants.CALL_NOTE.equals(type)) {
+ mNote.setCallDataId(cursor.getLong(DATA_ID_COLUMN));
+ } else {
+ Log.d(TAG, "Wrong note type with type:" + type);
+ }
+ } while (cursor.moveToNext());
+ }
+ cursor.close();
+ } else {
+ Log.e(TAG, "No data with id:" + mNoteId);
+ throw new IllegalArgumentException("Unable to find note's data with id " + mNoteId);
+ }
+ }
+
+ public static WorkingNote createEmptyNote(Context context, long folderId, int widgetId,
+ int widgetType, int defaultBgColorId) {
+ WorkingNote note = new WorkingNote(context, folderId);
+ note.setBgColorId(defaultBgColorId);
+ note.setWidgetId(widgetId);
+ note.setWidgetType(widgetType);
+ return note;
+ }
+
+ public static WorkingNote load(Context context, long id) {
+ return new WorkingNote(context, id, 0);
+ }
+
+ public synchronized boolean saveNote() {
+ if (isWorthSaving()) {
+ if (!existInDatabase()) {
+ if ((mNoteId = Note.getNewNoteId(mContext, mFolderId)) == 0) {
+ Log.e(TAG, "Create new note fail with id:" + mNoteId);
+ return false;
+ }
+ }
+
+ mNote.syncNote(mContext, mNoteId);
+
+ /**
+ * Update widget content if there exist any widget of this note
+ */
+ if (mWidgetId != AppWidgetManager.INVALID_APPWIDGET_ID
+ && mWidgetType != Notes.TYPE_WIDGET_INVALIDE
+ && mNoteSettingStatusListener != null) {
+ mNoteSettingStatusListener.onWidgetChanged();
+ }
+ return true;
+ } else {
+ return false;
+ }
+ }
+
+ public boolean existInDatabase() {
+ return mNoteId > 0;
+ }
+
+ private boolean isWorthSaving() {
+ if (mIsDeleted || (!existInDatabase() && TextUtils.isEmpty(mContent))
+ || (existInDatabase() && !mNote.isLocalModified())) {
+ return false;
+ } else {
+ return true;
+ }
+ }
+
+ public void setOnSettingStatusChangedListener(NoteSettingChangedListener l) {
+ mNoteSettingStatusListener = l;
+ }
+
+ public void setAlertDate(long date, boolean set) {
+ if (date != mAlertDate) {
+ mAlertDate = date;
+ mNote.setNoteValue(NoteColumns.ALERTED_DATE, String.valueOf(mAlertDate));
+ }
+ if (mNoteSettingStatusListener != null) {
+ mNoteSettingStatusListener.onClockAlertChanged(date, set);
+ }
+ }
+
+ public void markDeleted(boolean mark) {
+ mIsDeleted = mark;
+ if (mWidgetId != AppWidgetManager.INVALID_APPWIDGET_ID
+ && mWidgetType != Notes.TYPE_WIDGET_INVALIDE && mNoteSettingStatusListener != null) {
+ mNoteSettingStatusListener.onWidgetChanged();
+ }
+ }
+
+ public void setBgColorId(int id) {
+ if (id != mBgColorId) {
+ mBgColorId = id;
+ if (mNoteSettingStatusListener != null) {
+ mNoteSettingStatusListener.onBackgroundColorChanged();
+ }
+ mNote.setNoteValue(NoteColumns.BG_COLOR_ID, String.valueOf(id));
+ }
+ }
+
+ public void setCheckListMode(int mode) {
+ if (mMode != mode) {
+ if (mNoteSettingStatusListener != null) {
+ mNoteSettingStatusListener.onCheckListModeChanged(mMode, mode);
+ }
+ mMode = mode;
+ mNote.setTextData(TextNote.MODE, String.valueOf(mMode));
+ }
+ }
+
+ public void setWidgetType(int type) {
+ if (type != mWidgetType) {
+ mWidgetType = type;
+ mNote.setNoteValue(NoteColumns.WIDGET_TYPE, String.valueOf(mWidgetType));
+ }
+ }
+
+ public void setWidgetId(int id) {
+ if (id != mWidgetId) {
+ mWidgetId = id;
+ mNote.setNoteValue(NoteColumns.WIDGET_ID, String.valueOf(mWidgetId));
+ }
+ }
+
+ public void setWorkingText(String text) {
+ if (!TextUtils.equals(mContent, text)) {
+ mContent = text;
+ mNote.setTextData(DataColumns.CONTENT, mContent);
+ }
+ }
+
+ public void convertToCallNote(String phoneNumber, long callDate) {
+ mNote.setCallData(CallNote.CALL_DATE, String.valueOf(callDate));
+ mNote.setCallData(CallNote.PHONE_NUMBER, phoneNumber);
+ mNote.setNoteValue(NoteColumns.PARENT_ID, String.valueOf(Notes.ID_CALL_RECORD_FOLDER));
+ }
+
+ public boolean hasClockAlert() {
+ return (mAlertDate > 0 ? true : false);
+ }
+
+ public String getContent() {
+ return mContent;
+ }
+
+ public long getAlertDate() {
+ return mAlertDate;
+ }
+
+ public long getModifiedDate() {
+ return mModifiedDate;
+ }
+
+ public int getBgColorResId() {
+ return NoteBgResources.getNoteBgResource(mBgColorId);
+ }
+
+ public int getBgColorId() {
+ return mBgColorId;
+ }
+
+ public int getTitleBgResId() {
+ return NoteBgResources.getNoteTitleBgResource(mBgColorId);
+ }
+
+ public int getCheckListMode() {
+ return mMode;
+ }
+
+ public long getNoteId() {
+ return mNoteId;
+ }
+
+ public long getFolderId() {
+ return mFolderId;
+ }
+
+ public int getWidgetId() {
+ return mWidgetId;
+ }
+
+ public int getWidgetType() {
+ return mWidgetType;
+ }
+
+ public interface NoteSettingChangedListener {
+ /**
+ * Called when the background color of current note has just changed
+ */
+ void onBackgroundColorChanged();
+
+ /**
+ * Called when user set clock
+ */
+ void onClockAlertChanged(long date, boolean set);
+
+ /**
+ * Call when user create note from widget
+ */
+ void onWidgetChanged();
+
+ /**
+ * Call when switch between check list mode and normal mode
+ * @param oldMode is previous mode before change
+ * @param newMode is new mode
+ */
+ void onCheckListModeChanged(int oldMode, int newMode);
+ }
+}
diff --git a/src/src/Notes-master/src/net/micode/notes/tool/BackupUtils.java b/src/src/Notes-master/src/net/micode/notes/tool/BackupUtils.java
new file mode 100644
index 0000000..39f6ec4
--- /dev/null
+++ b/src/src/Notes-master/src/net/micode/notes/tool/BackupUtils.java
@@ -0,0 +1,344 @@
+/*
+ * Copyright (c) 2010-2011, The MiCode Open Source Community (www.micode.net)
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+
+package net.micode.notes.tool;
+
+import android.content.Context;
+import android.database.Cursor;
+import android.os.Environment;
+import android.text.TextUtils;
+import android.text.format.DateFormat;
+import android.util.Log;
+
+import net.micode.notes.R;
+import net.micode.notes.data.Notes;
+import net.micode.notes.data.Notes.DataColumns;
+import net.micode.notes.data.Notes.DataConstants;
+import net.micode.notes.data.Notes.NoteColumns;
+
+import java.io.File;
+import java.io.FileNotFoundException;
+import java.io.FileOutputStream;
+import java.io.IOException;
+import java.io.PrintStream;
+
+
+public class BackupUtils {
+ private static final String TAG = "BackupUtils";
+ // Singleton stuff
+ private static BackupUtils sInstance;
+
+ public static synchronized BackupUtils getInstance(Context context) {
+ if (sInstance == null) {
+ sInstance = new BackupUtils(context);
+ }
+ return sInstance;
+ }
+
+ /**
+ * Following states are signs to represents backup or restore
+ * status
+ */
+ // Currently, the sdcard is not mounted
+ public static final int STATE_SD_CARD_UNMOUONTED = 0;
+ // The backup file not exist
+ public static final int STATE_BACKUP_FILE_NOT_EXIST = 1;
+ // The data is not well formated, may be changed by other programs
+ public static final int STATE_DATA_DESTROIED = 2;
+ // Some run-time exception which causes restore or backup fails
+ public static final int STATE_SYSTEM_ERROR = 3;
+ // Backup or restore success
+ public static final int STATE_SUCCESS = 4;
+
+ private TextExport mTextExport;
+
+ private BackupUtils(Context context) {
+ mTextExport = new TextExport(context);
+ }
+
+ private static boolean externalStorageAvailable() {
+ return Environment.MEDIA_MOUNTED.equals(Environment.getExternalStorageState());
+ }
+
+ public int exportToText() {
+ return mTextExport.exportToText();
+ }
+
+ public String getExportedTextFileName() {
+ return mTextExport.mFileName;
+ }
+
+ public String getExportedTextFileDir() {
+ return mTextExport.mFileDirectory;
+ }
+
+ private static class TextExport {
+ private static final String[] NOTE_PROJECTION = {
+ NoteColumns.ID,
+ NoteColumns.MODIFIED_DATE,
+ NoteColumns.SNIPPET,
+ NoteColumns.TYPE
+ };
+
+ private static final int NOTE_COLUMN_ID = 0;
+
+ private static final int NOTE_COLUMN_MODIFIED_DATE = 1;
+
+ private static final int NOTE_COLUMN_SNIPPET = 2;
+
+ private static final String[] DATA_PROJECTION = {
+ DataColumns.CONTENT,
+ DataColumns.MIME_TYPE,
+ DataColumns.DATA1,
+ DataColumns.DATA2,
+ DataColumns.DATA3,
+ DataColumns.DATA4,
+ };
+
+ private static final int DATA_COLUMN_CONTENT = 0;
+
+ private static final int DATA_COLUMN_MIME_TYPE = 1;
+
+ private static final int DATA_COLUMN_CALL_DATE = 2;
+
+ private static final int DATA_COLUMN_PHONE_NUMBER = 4;
+
+ private final String [] TEXT_FORMAT;
+ private static final int FORMAT_FOLDER_NAME = 0;
+ private static final int FORMAT_NOTE_DATE = 1;
+ private static final int FORMAT_NOTE_CONTENT = 2;
+
+ private Context mContext;
+ private String mFileName;
+ private String mFileDirectory;
+
+ public TextExport(Context context) {
+ TEXT_FORMAT = context.getResources().getStringArray(R.array.format_for_exported_note);
+ mContext = context;
+ mFileName = "";
+ mFileDirectory = "";
+ }
+
+ private String getFormat(int id) {
+ return TEXT_FORMAT[id];
+ }
+
+ /**
+ * Export the folder identified by folder id to text
+ */
+ private void exportFolderToText(String folderId, PrintStream ps) {
+ // Query notes belong to this folder
+ Cursor notesCursor = mContext.getContentResolver().query(Notes.CONTENT_NOTE_URI,
+ NOTE_PROJECTION, NoteColumns.PARENT_ID + "=?", new String[] {
+ folderId
+ }, null);
+
+ if (notesCursor != null) {
+ if (notesCursor.moveToFirst()) {
+ do {
+ // Print note's last modified date
+ ps.println(String.format(getFormat(FORMAT_NOTE_DATE), DateFormat.format(
+ mContext.getString(R.string.format_datetime_mdhm),
+ notesCursor.getLong(NOTE_COLUMN_MODIFIED_DATE))));
+ // Query data belong to this note
+ String noteId = notesCursor.getString(NOTE_COLUMN_ID);
+ exportNoteToText(noteId, ps);
+ } while (notesCursor.moveToNext());
+ }
+ notesCursor.close();
+ }
+ }
+
+ /**
+ * Export note identified by id to a print stream
+ */
+ private void exportNoteToText(String noteId, PrintStream ps) {
+ Cursor dataCursor = mContext.getContentResolver().query(Notes.CONTENT_DATA_URI,
+ DATA_PROJECTION, DataColumns.NOTE_ID + "=?", new String[] {
+ noteId
+ }, null);
+
+ if (dataCursor != null) {
+ if (dataCursor.moveToFirst()) {
+ do {
+ String mimeType = dataCursor.getString(DATA_COLUMN_MIME_TYPE);
+ if (DataConstants.CALL_NOTE.equals(mimeType)) {
+ // Print phone number
+ String phoneNumber = dataCursor.getString(DATA_COLUMN_PHONE_NUMBER);
+ long callDate = dataCursor.getLong(DATA_COLUMN_CALL_DATE);
+ String location = dataCursor.getString(DATA_COLUMN_CONTENT);
+
+ if (!TextUtils.isEmpty(phoneNumber)) {
+ ps.println(String.format(getFormat(FORMAT_NOTE_CONTENT),
+ phoneNumber));
+ }
+ // Print call date
+ ps.println(String.format(getFormat(FORMAT_NOTE_CONTENT), DateFormat
+ .format(mContext.getString(R.string.format_datetime_mdhm),
+ callDate)));
+ // Print call attachment location
+ if (!TextUtils.isEmpty(location)) {
+ ps.println(String.format(getFormat(FORMAT_NOTE_CONTENT),
+ location));
+ }
+ } else if (DataConstants.NOTE.equals(mimeType)) {
+ String content = dataCursor.getString(DATA_COLUMN_CONTENT);
+ if (!TextUtils.isEmpty(content)) {
+ ps.println(String.format(getFormat(FORMAT_NOTE_CONTENT),
+ content));
+ }
+ }
+ } while (dataCursor.moveToNext());
+ }
+ dataCursor.close();
+ }
+ // print a line separator between note
+ try {
+ ps.write(new byte[] {
+ Character.LINE_SEPARATOR, Character.LETTER_NUMBER
+ });
+ } catch (IOException e) {
+ Log.e(TAG, e.toString());
+ }
+ }
+
+ /**
+ * Note will be exported as text which is user readable
+ */
+ public int exportToText() {
+ if (!externalStorageAvailable()) {
+ Log.d(TAG, "Media was not mounted");
+ return STATE_SD_CARD_UNMOUONTED;
+ }
+
+ PrintStream ps = getExportToTextPrintStream();
+ if (ps == null) {
+ Log.e(TAG, "get print stream error");
+ return STATE_SYSTEM_ERROR;
+ }
+ // First export folder and its notes
+ Cursor folderCursor = mContext.getContentResolver().query(
+ Notes.CONTENT_NOTE_URI,
+ NOTE_PROJECTION,
+ "(" + NoteColumns.TYPE + "=" + Notes.TYPE_FOLDER + " AND "
+ + NoteColumns.PARENT_ID + "<>" + Notes.ID_TRASH_FOLER + ") OR "
+ + NoteColumns.ID + "=" + Notes.ID_CALL_RECORD_FOLDER, null, null);
+
+ if (folderCursor != null) {
+ if (folderCursor.moveToFirst()) {
+ do {
+ // Print folder's name
+ String folderName = "";
+ if(folderCursor.getLong(NOTE_COLUMN_ID) == Notes.ID_CALL_RECORD_FOLDER) {
+ folderName = mContext.getString(R.string.call_record_folder_name);
+ } else {
+ folderName = folderCursor.getString(NOTE_COLUMN_SNIPPET);
+ }
+ if (!TextUtils.isEmpty(folderName)) {
+ ps.println(String.format(getFormat(FORMAT_FOLDER_NAME), folderName));
+ }
+ String folderId = folderCursor.getString(NOTE_COLUMN_ID);
+ exportFolderToText(folderId, ps);
+ } while (folderCursor.moveToNext());
+ }
+ folderCursor.close();
+ }
+
+ // Export notes in root's folder
+ Cursor noteCursor = mContext.getContentResolver().query(
+ Notes.CONTENT_NOTE_URI,
+ NOTE_PROJECTION,
+ NoteColumns.TYPE + "=" + +Notes.TYPE_NOTE + " AND " + NoteColumns.PARENT_ID
+ + "=0", null, null);
+
+ if (noteCursor != null) {
+ if (noteCursor.moveToFirst()) {
+ do {
+ ps.println(String.format(getFormat(FORMAT_NOTE_DATE), DateFormat.format(
+ mContext.getString(R.string.format_datetime_mdhm),
+ noteCursor.getLong(NOTE_COLUMN_MODIFIED_DATE))));
+ // Query data belong to this note
+ String noteId = noteCursor.getString(NOTE_COLUMN_ID);
+ exportNoteToText(noteId, ps);
+ } while (noteCursor.moveToNext());
+ }
+ noteCursor.close();
+ }
+ ps.close();
+
+ return STATE_SUCCESS;
+ }
+
+ /**
+ * Get a print stream pointed to the file {@generateExportedTextFile}
+ */
+ private PrintStream getExportToTextPrintStream() {
+ File file = generateFileMountedOnSDcard(mContext, R.string.file_path,
+ R.string.file_name_txt_format);
+ if (file == null) {
+ Log.e(TAG, "create file to exported failed");
+ return null;
+ }
+ mFileName = file.getName();
+ mFileDirectory = mContext.getString(R.string.file_path);
+ PrintStream ps = null;
+ try {
+ FileOutputStream fos = new FileOutputStream(file);
+ ps = new PrintStream(fos);
+ } catch (FileNotFoundException e) {
+ e.printStackTrace();
+ return null;
+ } catch (NullPointerException e) {
+ e.printStackTrace();
+ return null;
+ }
+ return ps;
+ }
+ }
+
+ /**
+ * Generate the text file to store imported data
+ */
+ private static File generateFileMountedOnSDcard(Context context, int filePathResId, int fileNameFormatResId) {
+ StringBuilder sb = new StringBuilder();
+ sb.append(Environment.getExternalStorageDirectory());
+ sb.append(context.getString(filePathResId));
+ File filedir = new File(sb.toString());
+ sb.append(context.getString(
+ fileNameFormatResId,
+ DateFormat.format(context.getString(R.string.format_date_ymd),
+ System.currentTimeMillis())));
+ File file = new File(sb.toString());
+
+ try {
+ if (!filedir.exists()) {
+ filedir.mkdir();
+ }
+ if (!file.exists()) {
+ file.createNewFile();
+ }
+ return file;
+ } catch (SecurityException e) {
+ e.printStackTrace();
+ } catch (IOException e) {
+ e.printStackTrace();
+ }
+
+ return null;
+ }
+}
+
+
diff --git a/src/src/Notes-master/src/net/micode/notes/tool/DataUtils.java b/src/src/Notes-master/src/net/micode/notes/tool/DataUtils.java
new file mode 100644
index 0000000..2a14982
--- /dev/null
+++ b/src/src/Notes-master/src/net/micode/notes/tool/DataUtils.java
@@ -0,0 +1,295 @@
+/*
+ * Copyright (c) 2010-2011, The MiCode Open Source Community (www.micode.net)
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+
+package net.micode.notes.tool;
+
+import android.content.ContentProviderOperation;
+import android.content.ContentProviderResult;
+import android.content.ContentResolver;
+import android.content.ContentUris;
+import android.content.ContentValues;
+import android.content.OperationApplicationException;
+import android.database.Cursor;
+import android.os.RemoteException;
+import android.util.Log;
+
+import net.micode.notes.data.Notes;
+import net.micode.notes.data.Notes.CallNote;
+import net.micode.notes.data.Notes.NoteColumns;
+import net.micode.notes.ui.NotesListAdapter.AppWidgetAttribute;
+
+import java.util.ArrayList;
+import java.util.HashSet;
+
+
+public class DataUtils {
+ public static final String TAG = "DataUtils";
+ public static boolean batchDeleteNotes(ContentResolver resolver, HashSet ids) {
+ if (ids == null) {
+ Log.d(TAG, "the ids is null");
+ return true;
+ }
+ if (ids.size() == 0) {
+ Log.d(TAG, "no id is in the hashset");
+ return true;
+ }
+
+ ArrayList operationList = new ArrayList();
+ for (long id : ids) {
+ if(id == Notes.ID_ROOT_FOLDER) {
+ Log.e(TAG, "Don't delete system folder root");
+ continue;
+ }
+ ContentProviderOperation.Builder builder = ContentProviderOperation
+ .newDelete(ContentUris.withAppendedId(Notes.CONTENT_NOTE_URI, id));
+ operationList.add(builder.build());
+ }
+ try {
+ ContentProviderResult[] results = resolver.applyBatch(Notes.AUTHORITY, operationList);
+ if (results == null || results.length == 0 || results[0] == null) {
+ Log.d(TAG, "delete notes failed, ids:" + ids.toString());
+ return false;
+ }
+ return true;
+ } catch (RemoteException e) {
+ Log.e(TAG, String.format("%s: %s", e.toString(), e.getMessage()));
+ } catch (OperationApplicationException e) {
+ Log.e(TAG, String.format("%s: %s", e.toString(), e.getMessage()));
+ }
+ return false;
+ }
+
+ public static void moveNoteToFoler(ContentResolver resolver, long id, long srcFolderId, long desFolderId) {
+ ContentValues values = new ContentValues();
+ values.put(NoteColumns.PARENT_ID, desFolderId);
+ values.put(NoteColumns.ORIGIN_PARENT_ID, srcFolderId);
+ values.put(NoteColumns.LOCAL_MODIFIED, 1);
+ resolver.update(ContentUris.withAppendedId(Notes.CONTENT_NOTE_URI, id), values, null, null);
+ }
+
+ public static boolean batchMoveToFolder(ContentResolver resolver, HashSet ids,
+ long folderId) {
+ if (ids == null) {
+ Log.d(TAG, "the ids is null");
+ return true;
+ }
+
+ ArrayList operationList = new ArrayList();
+ for (long id : ids) {
+ ContentProviderOperation.Builder builder = ContentProviderOperation
+ .newUpdate(ContentUris.withAppendedId(Notes.CONTENT_NOTE_URI, id));
+ builder.withValue(NoteColumns.PARENT_ID, folderId);
+ builder.withValue(NoteColumns.LOCAL_MODIFIED, 1);
+ operationList.add(builder.build());
+ }
+
+ try {
+ ContentProviderResult[] results = resolver.applyBatch(Notes.AUTHORITY, operationList);
+ if (results == null || results.length == 0 || results[0] == null) {
+ Log.d(TAG, "delete notes failed, ids:" + ids.toString());
+ return false;
+ }
+ return true;
+ } catch (RemoteException e) {
+ Log.e(TAG, String.format("%s: %s", e.toString(), e.getMessage()));
+ } catch (OperationApplicationException e) {
+ Log.e(TAG, String.format("%s: %s", e.toString(), e.getMessage()));
+ }
+ return false;
+ }
+
+ /**
+ * Get the all folder count except system folders {@link Notes#TYPE_SYSTEM}}
+ */
+ public static int getUserFolderCount(ContentResolver resolver) {
+ Cursor cursor =resolver.query(Notes.CONTENT_NOTE_URI,
+ new String[] { "COUNT(*)" },
+ NoteColumns.TYPE + "=? AND " + NoteColumns.PARENT_ID + "<>?",
+ new String[] { String.valueOf(Notes.TYPE_FOLDER), String.valueOf(Notes.ID_TRASH_FOLER)},
+ null);
+
+ int count = 0;
+ if(cursor != null) {
+ if(cursor.moveToFirst()) {
+ try {
+ count = cursor.getInt(0);
+ } catch (IndexOutOfBoundsException e) {
+ Log.e(TAG, "get folder count failed:" + e.toString());
+ } finally {
+ cursor.close();
+ }
+ }
+ }
+ return count;
+ }
+
+ public static boolean visibleInNoteDatabase(ContentResolver resolver, long noteId, int type) {
+ Cursor cursor = resolver.query(ContentUris.withAppendedId(Notes.CONTENT_NOTE_URI, noteId),
+ null,
+ NoteColumns.TYPE + "=? AND " + NoteColumns.PARENT_ID + "<>" + Notes.ID_TRASH_FOLER,
+ new String [] {String.valueOf(type)},
+ null);
+
+ boolean exist = false;
+ if (cursor != null) {
+ if (cursor.getCount() > 0) {
+ exist = true;
+ }
+ cursor.close();
+ }
+ return exist;
+ }
+
+ public static boolean existInNoteDatabase(ContentResolver resolver, long noteId) {
+ Cursor cursor = resolver.query(ContentUris.withAppendedId(Notes.CONTENT_NOTE_URI, noteId),
+ null, null, null, null);
+
+ boolean exist = false;
+ if (cursor != null) {
+ if (cursor.getCount() > 0) {
+ exist = true;
+ }
+ cursor.close();
+ }
+ return exist;
+ }
+
+ public static boolean existInDataDatabase(ContentResolver resolver, long dataId) {
+ Cursor cursor = resolver.query(ContentUris.withAppendedId(Notes.CONTENT_DATA_URI, dataId),
+ null, null, null, null);
+
+ boolean exist = false;
+ if (cursor != null) {
+ if (cursor.getCount() > 0) {
+ exist = true;
+ }
+ cursor.close();
+ }
+ return exist;
+ }
+
+ public static boolean checkVisibleFolderName(ContentResolver resolver, String name) {
+ Cursor cursor = resolver.query(Notes.CONTENT_NOTE_URI, null,
+ NoteColumns.TYPE + "=" + Notes.TYPE_FOLDER +
+ " AND " + NoteColumns.PARENT_ID + "<>" + Notes.ID_TRASH_FOLER +
+ " AND " + NoteColumns.SNIPPET + "=?",
+ new String[] { name }, null);
+ boolean exist = false;
+ if(cursor != null) {
+ if(cursor.getCount() > 0) {
+ exist = true;
+ }
+ cursor.close();
+ }
+ return exist;
+ }
+
+ public static HashSet getFolderNoteWidget(ContentResolver resolver, long folderId) {
+ Cursor c = resolver.query(Notes.CONTENT_NOTE_URI,
+ new String[] { NoteColumns.WIDGET_ID, NoteColumns.WIDGET_TYPE },
+ NoteColumns.PARENT_ID + "=?",
+ new String[] { String.valueOf(folderId) },
+ null);
+
+ HashSet set = null;
+ if (c != null) {
+ if (c.moveToFirst()) {
+ set = new HashSet();
+ do {
+ try {
+ AppWidgetAttribute widget = new AppWidgetAttribute();
+ widget.widgetId = c.getInt(0);
+ widget.widgetType = c.getInt(1);
+ set.add(widget);
+ } catch (IndexOutOfBoundsException e) {
+ Log.e(TAG, e.toString());
+ }
+ } while (c.moveToNext());
+ }
+ c.close();
+ }
+ return set;
+ }
+
+ public static String getCallNumberByNoteId(ContentResolver resolver, long noteId) {
+ Cursor cursor = resolver.query(Notes.CONTENT_DATA_URI,
+ new String [] { CallNote.PHONE_NUMBER },
+ CallNote.NOTE_ID + "=? AND " + CallNote.MIME_TYPE + "=?",
+ new String [] { String.valueOf(noteId), CallNote.CONTENT_ITEM_TYPE },
+ null);
+
+ if (cursor != null && cursor.moveToFirst()) {
+ try {
+ return cursor.getString(0);
+ } catch (IndexOutOfBoundsException e) {
+ Log.e(TAG, "Get call number fails " + e.toString());
+ } finally {
+ cursor.close();
+ }
+ }
+ return "";
+ }
+
+ public static long getNoteIdByPhoneNumberAndCallDate(ContentResolver resolver, String phoneNumber, long callDate) {
+ Cursor cursor = resolver.query(Notes.CONTENT_DATA_URI,
+ new String [] { CallNote.NOTE_ID },
+ CallNote.CALL_DATE + "=? AND " + CallNote.MIME_TYPE + "=? AND PHONE_NUMBERS_EQUAL("
+ + CallNote.PHONE_NUMBER + ",?)",
+ new String [] { String.valueOf(callDate), CallNote.CONTENT_ITEM_TYPE, phoneNumber },
+ null);
+
+ if (cursor != null) {
+ if (cursor.moveToFirst()) {
+ try {
+ return cursor.getLong(0);
+ } catch (IndexOutOfBoundsException e) {
+ Log.e(TAG, "Get call note id fails " + e.toString());
+ }
+ }
+ cursor.close();
+ }
+ return 0;
+ }
+
+ public static String getSnippetById(ContentResolver resolver, long noteId) {
+ Cursor cursor = resolver.query(Notes.CONTENT_NOTE_URI,
+ new String [] { NoteColumns.SNIPPET },
+ NoteColumns.ID + "=?",
+ new String [] { String.valueOf(noteId)},
+ null);
+
+ if (cursor != null) {
+ String snippet = "";
+ if (cursor.moveToFirst()) {
+ snippet = cursor.getString(0);
+ }
+ cursor.close();
+ return snippet;
+ }
+ throw new IllegalArgumentException("Note is not found with id: " + noteId);
+ }
+
+ public static String getFormattedSnippet(String snippet) {
+ if (snippet != null) {
+ snippet = snippet.trim();
+ int index = snippet.indexOf('\n');
+ if (index != -1) {
+ snippet = snippet.substring(0, index);
+ }
+ }
+ return snippet;
+ }
+}
diff --git a/src/src/Notes-master/src/net/micode/notes/tool/GTaskStringUtils.java b/src/src/Notes-master/src/net/micode/notes/tool/GTaskStringUtils.java
new file mode 100644
index 0000000..666b729
--- /dev/null
+++ b/src/src/Notes-master/src/net/micode/notes/tool/GTaskStringUtils.java
@@ -0,0 +1,113 @@
+/*
+ * Copyright (c) 2010-2011, The MiCode Open Source Community (www.micode.net)
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+
+package net.micode.notes.tool;
+
+public class GTaskStringUtils {
+
+ public final static String GTASK_JSON_ACTION_ID = "action_id";
+
+ public final static String GTASK_JSON_ACTION_LIST = "action_list";
+
+ public final static String GTASK_JSON_ACTION_TYPE = "action_type";
+
+ public final static String GTASK_JSON_ACTION_TYPE_CREATE = "create";
+
+ public final static String GTASK_JSON_ACTION_TYPE_GETALL = "get_all";
+
+ public final static String GTASK_JSON_ACTION_TYPE_MOVE = "move";
+
+ public final static String GTASK_JSON_ACTION_TYPE_UPDATE = "update";
+
+ public final static String GTASK_JSON_CREATOR_ID = "creator_id";
+
+ public final static String GTASK_JSON_CHILD_ENTITY = "child_entity";
+
+ public final static String GTASK_JSON_CLIENT_VERSION = "client_version";
+
+ public final static String GTASK_JSON_COMPLETED = "completed";
+
+ public final static String GTASK_JSON_CURRENT_LIST_ID = "current_list_id";
+
+ public final static String GTASK_JSON_DEFAULT_LIST_ID = "default_list_id";
+
+ public final static String GTASK_JSON_DELETED = "deleted";
+
+ public final static String GTASK_JSON_DEST_LIST = "dest_list";
+
+ public final static String GTASK_JSON_DEST_PARENT = "dest_parent";
+
+ public final static String GTASK_JSON_DEST_PARENT_TYPE = "dest_parent_type";
+
+ public final static String GTASK_JSON_ENTITY_DELTA = "entity_delta";
+
+ public final static String GTASK_JSON_ENTITY_TYPE = "entity_type";
+
+ public final static String GTASK_JSON_GET_DELETED = "get_deleted";
+
+ public final static String GTASK_JSON_ID = "id";
+
+ public final static String GTASK_JSON_INDEX = "index";
+
+ public final static String GTASK_JSON_LAST_MODIFIED = "last_modified";
+
+ public final static String GTASK_JSON_LATEST_SYNC_POINT = "latest_sync_point";
+
+ public final static String GTASK_JSON_LIST_ID = "list_id";
+
+ public final static String GTASK_JSON_LISTS = "lists";
+
+ public final static String GTASK_JSON_NAME = "name";
+
+ public final static String GTASK_JSON_NEW_ID = "new_id";
+
+ public final static String GTASK_JSON_NOTES = "notes";
+
+ public final static String GTASK_JSON_PARENT_ID = "parent_id";
+
+ public final static String GTASK_JSON_PRIOR_SIBLING_ID = "prior_sibling_id";
+
+ public final static String GTASK_JSON_RESULTS = "results";
+
+ public final static String GTASK_JSON_SOURCE_LIST = "source_list";
+
+ public final static String GTASK_JSON_TASKS = "tasks";
+
+ public final static String GTASK_JSON_TYPE = "type";
+
+ public final static String GTASK_JSON_TYPE_GROUP = "GROUP";
+
+ public final static String GTASK_JSON_TYPE_TASK = "TASK";
+
+ public final static String GTASK_JSON_USER = "user";
+
+ public final static String MIUI_FOLDER_PREFFIX = "[MIUI_Notes]";
+
+ public final static String FOLDER_DEFAULT = "Default";
+
+ public final static String FOLDER_CALL_NOTE = "Call_Note";
+
+ public final static String FOLDER_META = "METADATA";
+
+ public final static String META_HEAD_GTASK_ID = "meta_gid";
+
+ public final static String META_HEAD_NOTE = "meta_note";
+
+ public final static String META_HEAD_DATA = "meta_data";
+
+ public final static String META_NOTE_NAME = "[META INFO] DON'T UPDATE AND DELETE";
+
+}
diff --git a/src/src/Notes-master/src/net/micode/notes/tool/ResourceParser.java b/src/src/Notes-master/src/net/micode/notes/tool/ResourceParser.java
new file mode 100644
index 0000000..1ad3ad6
--- /dev/null
+++ b/src/src/Notes-master/src/net/micode/notes/tool/ResourceParser.java
@@ -0,0 +1,181 @@
+/*
+ * Copyright (c) 2010-2011, The MiCode Open Source Community (www.micode.net)
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+
+package net.micode.notes.tool;
+
+import android.content.Context;
+import android.preference.PreferenceManager;
+
+import net.micode.notes.R;
+import net.micode.notes.ui.NotesPreferenceActivity;
+
+public class ResourceParser {
+
+ public static final int YELLOW = 0;
+ public static final int BLUE = 1;
+ public static final int WHITE = 2;
+ public static final int GREEN = 3;
+ public static final int RED = 4;
+
+ public static final int BG_DEFAULT_COLOR = YELLOW;
+
+ public static final int TEXT_SMALL = 0;
+ public static final int TEXT_MEDIUM = 1;
+ public static final int TEXT_LARGE = 2;
+ public static final int TEXT_SUPER = 3;
+
+ public static final int BG_DEFAULT_FONT_SIZE = TEXT_MEDIUM;
+
+ public static class NoteBgResources {
+ private final static int [] BG_EDIT_RESOURCES = new int [] {
+ R.drawable.edit_yellow,
+ R.drawable.edit_blue,
+ R.drawable.edit_white,
+ R.drawable.edit_green,
+ R.drawable.edit_red
+ };
+
+ private final static int [] BG_EDIT_TITLE_RESOURCES = new int [] {
+ R.drawable.edit_title_yellow,
+ R.drawable.edit_title_blue,
+ R.drawable.edit_title_white,
+ R.drawable.edit_title_green,
+ R.drawable.edit_title_red
+ };
+
+ public static int getNoteBgResource(int id) {
+ return BG_EDIT_RESOURCES[id];
+ }
+
+ public static int getNoteTitleBgResource(int id) {
+ return BG_EDIT_TITLE_RESOURCES[id];
+ }
+ }
+
+ public static int getDefaultBgId(Context context) {
+ if (PreferenceManager.getDefaultSharedPreferences(context).getBoolean(
+ NotesPreferenceActivity.PREFERENCE_SET_BG_COLOR_KEY, false)) {
+ return (int) (Math.random() * NoteBgResources.BG_EDIT_RESOURCES.length);
+ } else {
+ return BG_DEFAULT_COLOR;
+ }
+ }
+
+ public static class NoteItemBgResources {
+ private final static int [] BG_FIRST_RESOURCES = new int [] {
+ R.drawable.list_yellow_up,
+ R.drawable.list_blue_up,
+ R.drawable.list_white_up,
+ R.drawable.list_green_up,
+ R.drawable.list_red_up
+ };
+
+ private final static int [] BG_NORMAL_RESOURCES = new int [] {
+ R.drawable.list_yellow_middle,
+ R.drawable.list_blue_middle,
+ R.drawable.list_white_middle,
+ R.drawable.list_green_middle,
+ R.drawable.list_red_middle
+ };
+
+ private final static int [] BG_LAST_RESOURCES = new int [] {
+ R.drawable.list_yellow_down,
+ R.drawable.list_blue_down,
+ R.drawable.list_white_down,
+ R.drawable.list_green_down,
+ R.drawable.list_red_down,
+ };
+
+ private final static int [] BG_SINGLE_RESOURCES = new int [] {
+ R.drawable.list_yellow_single,
+ R.drawable.list_blue_single,
+ R.drawable.list_white_single,
+ R.drawable.list_green_single,
+ R.drawable.list_red_single
+ };
+
+ public static int getNoteBgFirstRes(int id) {
+ return BG_FIRST_RESOURCES[id];
+ }
+
+ public static int getNoteBgLastRes(int id) {
+ return BG_LAST_RESOURCES[id];
+ }
+
+ public static int getNoteBgSingleRes(int id) {
+ return BG_SINGLE_RESOURCES[id];
+ }
+
+ public static int getNoteBgNormalRes(int id) {
+ return BG_NORMAL_RESOURCES[id];
+ }
+
+ public static int getFolderBgRes() {
+ return R.drawable.list_folder;
+ }
+ }
+
+ public static class WidgetBgResources {
+ private final static int [] BG_2X_RESOURCES = new int [] {
+ R.drawable.widget_2x_yellow,
+ R.drawable.widget_2x_blue,
+ R.drawable.widget_2x_white,
+ R.drawable.widget_2x_green,
+ R.drawable.widget_2x_red,
+ };
+
+ public static int getWidget2xBgResource(int id) {
+ return BG_2X_RESOURCES[id];
+ }
+
+ private final static int [] BG_4X_RESOURCES = new int [] {
+ R.drawable.widget_4x_yellow,
+ R.drawable.widget_4x_blue,
+ R.drawable.widget_4x_white,
+ R.drawable.widget_4x_green,
+ R.drawable.widget_4x_red
+ };
+
+ public static int getWidget4xBgResource(int id) {
+ return BG_4X_RESOURCES[id];
+ }
+ }
+
+ public static class TextAppearanceResources {
+ private final static int [] TEXTAPPEARANCE_RESOURCES = new int [] {
+ R.style.TextAppearanceNormal,
+ R.style.TextAppearanceMedium,
+ R.style.TextAppearanceLarge,
+ R.style.TextAppearanceSuper
+ };
+
+ public static int getTexAppearanceResource(int id) {
+ /**
+ * HACKME: Fix bug of store the resource id in shared preference.
+ * The id may larger than the length of resources, in this case,
+ * return the {@link ResourceParser#BG_DEFAULT_FONT_SIZE}
+ */
+ if (id >= TEXTAPPEARANCE_RESOURCES.length) {
+ return BG_DEFAULT_FONT_SIZE;
+ }
+ return TEXTAPPEARANCE_RESOURCES[id];
+ }
+
+ public static int getResourcesSize() {
+ return TEXTAPPEARANCE_RESOURCES.length;
+ }
+ }
+}
diff --git a/src/src/Notes-master/src/net/micode/notes/ui/AlarmAlertActivity.java b/src/src/Notes-master/src/net/micode/notes/ui/AlarmAlertActivity.java
new file mode 100644
index 0000000..85723be
--- /dev/null
+++ b/src/src/Notes-master/src/net/micode/notes/ui/AlarmAlertActivity.java
@@ -0,0 +1,158 @@
+/*
+ * Copyright (c) 2010-2011, The MiCode Open Source Community (www.micode.net)
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+
+package net.micode.notes.ui;
+
+import android.app.Activity;
+import android.app.AlertDialog;
+import android.content.Context;
+import android.content.DialogInterface;
+import android.content.DialogInterface.OnClickListener;
+import android.content.DialogInterface.OnDismissListener;
+import android.content.Intent;
+import android.media.AudioManager;
+import android.media.MediaPlayer;
+import android.media.RingtoneManager;
+import android.net.Uri;
+import android.os.Bundle;
+import android.os.PowerManager;
+import android.provider.Settings;
+import android.view.Window;
+import android.view.WindowManager;
+
+import net.micode.notes.R;
+import net.micode.notes.data.Notes;
+import net.micode.notes.tool.DataUtils;
+
+import java.io.IOException;
+
+
+public class AlarmAlertActivity extends Activity implements OnClickListener, OnDismissListener {
+ private long mNoteId;
+ private String mSnippet;
+ private static final int SNIPPET_PREW_MAX_LEN = 60;
+ MediaPlayer mPlayer;
+
+ @Override
+ protected void onCreate(Bundle savedInstanceState) {
+ super.onCreate(savedInstanceState);
+ requestWindowFeature(Window.FEATURE_NO_TITLE);
+
+ final Window win = getWindow();
+ win.addFlags(WindowManager.LayoutParams.FLAG_SHOW_WHEN_LOCKED);
+
+ if (!isScreenOn()) {
+ win.addFlags(WindowManager.LayoutParams.FLAG_KEEP_SCREEN_ON
+ | WindowManager.LayoutParams.FLAG_TURN_SCREEN_ON
+ | WindowManager.LayoutParams.FLAG_ALLOW_LOCK_WHILE_SCREEN_ON
+ | WindowManager.LayoutParams.FLAG_LAYOUT_INSET_DECOR);
+ }
+
+ Intent intent = getIntent();
+
+ try {
+ mNoteId = Long.valueOf(intent.getData().getPathSegments().get(1));
+ mSnippet = DataUtils.getSnippetById(this.getContentResolver(), mNoteId);
+ mSnippet = mSnippet.length() > SNIPPET_PREW_MAX_LEN ? mSnippet.substring(0,
+ SNIPPET_PREW_MAX_LEN) + getResources().getString(R.string.notelist_string_info)
+ : mSnippet;
+ } catch (IllegalArgumentException e) {
+ e.printStackTrace();
+ return;
+ }
+
+ mPlayer = new MediaPlayer();
+ if (DataUtils.visibleInNoteDatabase(getContentResolver(), mNoteId, Notes.TYPE_NOTE)) {
+ showActionDialog();
+ playAlarmSound();
+ } else {
+ finish();
+ }
+ }
+
+ private boolean isScreenOn() {
+ PowerManager pm = (PowerManager) getSystemService(Context.POWER_SERVICE);
+ return pm.isScreenOn();
+ }
+
+ private void playAlarmSound() {
+ Uri url = RingtoneManager.getActualDefaultRingtoneUri(this, RingtoneManager.TYPE_ALARM);
+
+ int silentModeStreams = Settings.System.getInt(getContentResolver(),
+ Settings.System.MODE_RINGER_STREAMS_AFFECTED, 0);
+
+ if ((silentModeStreams & (1 << AudioManager.STREAM_ALARM)) != 0) {
+ mPlayer.setAudioStreamType(silentModeStreams);
+ } else {
+ mPlayer.setAudioStreamType(AudioManager.STREAM_ALARM);
+ }
+ try {
+ mPlayer.setDataSource(this, url);
+ mPlayer.prepare();
+ mPlayer.setLooping(true);
+ mPlayer.start();
+ } catch (IllegalArgumentException e) {
+ // TODO Auto-generated catch block
+ e.printStackTrace();
+ } catch (SecurityException e) {
+ // TODO Auto-generated catch block
+ e.printStackTrace();
+ } catch (IllegalStateException e) {
+ // TODO Auto-generated catch block
+ e.printStackTrace();
+ } catch (IOException e) {
+ // TODO Auto-generated catch block
+ e.printStackTrace();
+ }
+ }
+
+ private void showActionDialog() {
+ AlertDialog.Builder dialog = new AlertDialog.Builder(this);
+ dialog.setTitle(R.string.app_name);
+ dialog.setMessage(mSnippet);
+ dialog.setPositiveButton(R.string.notealert_ok, this);
+ if (isScreenOn()) {
+ dialog.setNegativeButton(R.string.notealert_enter, this);
+ }
+ dialog.show().setOnDismissListener(this);
+ }
+
+ public void onClick(DialogInterface dialog, int which) {
+ switch (which) {
+ case DialogInterface.BUTTON_NEGATIVE:
+ Intent intent = new Intent(this, NoteEditActivity.class);
+ intent.setAction(Intent.ACTION_VIEW);
+ intent.putExtra(Intent.EXTRA_UID, mNoteId);
+ startActivity(intent);
+ break;
+ default:
+ break;
+ }
+ }
+
+ public void onDismiss(DialogInterface dialog) {
+ stopAlarmSound();
+ finish();
+ }
+
+ private void stopAlarmSound() {
+ if (mPlayer != null) {
+ mPlayer.stop();
+ mPlayer.release();
+ mPlayer = null;
+ }
+ }
+}
diff --git a/src/src/Notes-master/src/net/micode/notes/ui/AlarmInitReceiver.java b/src/src/Notes-master/src/net/micode/notes/ui/AlarmInitReceiver.java
new file mode 100644
index 0000000..f221202
--- /dev/null
+++ b/src/src/Notes-master/src/net/micode/notes/ui/AlarmInitReceiver.java
@@ -0,0 +1,65 @@
+/*
+ * Copyright (c) 2010-2011, The MiCode Open Source Community (www.micode.net)
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+
+package net.micode.notes.ui;
+
+import android.app.AlarmManager;
+import android.app.PendingIntent;
+import android.content.BroadcastReceiver;
+import android.content.ContentUris;
+import android.content.Context;
+import android.content.Intent;
+import android.database.Cursor;
+
+import net.micode.notes.data.Notes;
+import net.micode.notes.data.Notes.NoteColumns;
+
+
+public class AlarmInitReceiver extends BroadcastReceiver {
+
+ private static final String [] PROJECTION = new String [] {
+ NoteColumns.ID,
+ NoteColumns.ALERTED_DATE
+ };
+
+ private static final int COLUMN_ID = 0;
+ private static final int COLUMN_ALERTED_DATE = 1;
+
+ @Override
+ public void onReceive(Context context, Intent intent) {
+ long currentDate = System.currentTimeMillis();
+ Cursor c = context.getContentResolver().query(Notes.CONTENT_NOTE_URI,
+ PROJECTION,
+ NoteColumns.ALERTED_DATE + ">? AND " + NoteColumns.TYPE + "=" + Notes.TYPE_NOTE,
+ new String[] { String.valueOf(currentDate) },
+ null);
+
+ if (c != null) {
+ if (c.moveToFirst()) {
+ do {
+ long alertDate = c.getLong(COLUMN_ALERTED_DATE);
+ Intent sender = new Intent(context, AlarmReceiver.class);
+ sender.setData(ContentUris.withAppendedId(Notes.CONTENT_NOTE_URI, c.getLong(COLUMN_ID)));
+ PendingIntent pendingIntent = PendingIntent.getBroadcast(context, 0, sender, 0);
+ AlarmManager alermManager = (AlarmManager) context
+ .getSystemService(Context.ALARM_SERVICE);
+ alermManager.set(AlarmManager.RTC_WAKEUP, alertDate, pendingIntent);
+ } while (c.moveToNext());
+ }
+ c.close();
+ }
+ }
+}
diff --git a/src/src/Notes-master/src/net/micode/notes/ui/AlarmReceiver.java b/src/src/Notes-master/src/net/micode/notes/ui/AlarmReceiver.java
new file mode 100644
index 0000000..54e503b
--- /dev/null
+++ b/src/src/Notes-master/src/net/micode/notes/ui/AlarmReceiver.java
@@ -0,0 +1,30 @@
+/*
+ * Copyright (c) 2010-2011, The MiCode Open Source Community (www.micode.net)
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+
+package net.micode.notes.ui;
+
+import android.content.BroadcastReceiver;
+import android.content.Context;
+import android.content.Intent;
+
+public class AlarmReceiver extends BroadcastReceiver {
+ @Override
+ public void onReceive(Context context, Intent intent) {
+ intent.setClass(context, AlarmAlertActivity.class);
+ intent.addFlags(Intent.FLAG_ACTIVITY_NEW_TASK);
+ context.startActivity(intent);
+ }
+}
diff --git a/src/src/Notes-master/src/net/micode/notes/ui/DateTimePicker.java b/src/src/Notes-master/src/net/micode/notes/ui/DateTimePicker.java
new file mode 100644
index 0000000..496b0cd
--- /dev/null
+++ b/src/src/Notes-master/src/net/micode/notes/ui/DateTimePicker.java
@@ -0,0 +1,485 @@
+/*
+ * Copyright (c) 2010-2011, The MiCode Open Source Community (www.micode.net)
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+
+package net.micode.notes.ui;
+
+import java.text.DateFormatSymbols;
+import java.util.Calendar;
+
+import net.micode.notes.R;
+
+
+import android.content.Context;
+import android.text.format.DateFormat;
+import android.view.View;
+import android.widget.FrameLayout;
+import android.widget.NumberPicker;
+
+public class DateTimePicker extends FrameLayout {
+
+ private static final boolean DEFAULT_ENABLE_STATE = true;
+
+ private static final int HOURS_IN_HALF_DAY = 12;
+ private static final int HOURS_IN_ALL_DAY = 24;
+ private static final int DAYS_IN_ALL_WEEK = 7;
+ private static final int DATE_SPINNER_MIN_VAL = 0;
+ private static final int DATE_SPINNER_MAX_VAL = DAYS_IN_ALL_WEEK - 1;
+ private static final int HOUR_SPINNER_MIN_VAL_24_HOUR_VIEW = 0;
+ private static final int HOUR_SPINNER_MAX_VAL_24_HOUR_VIEW = 23;
+ private static final int HOUR_SPINNER_MIN_VAL_12_HOUR_VIEW = 1;
+ private static final int HOUR_SPINNER_MAX_VAL_12_HOUR_VIEW = 12;
+ private static final int MINUT_SPINNER_MIN_VAL = 0;
+ private static final int MINUT_SPINNER_MAX_VAL = 59;
+ private static final int AMPM_SPINNER_MIN_VAL = 0;
+ private static final int AMPM_SPINNER_MAX_VAL = 1;
+
+ private final NumberPicker mDateSpinner;
+ private final NumberPicker mHourSpinner;
+ private final NumberPicker mMinuteSpinner;
+ private final NumberPicker mAmPmSpinner;
+ private Calendar mDate;
+
+ private String[] mDateDisplayValues = new String[DAYS_IN_ALL_WEEK];
+
+ private boolean mIsAm;
+
+ private boolean mIs24HourView;
+
+ private boolean mIsEnabled = DEFAULT_ENABLE_STATE;
+
+ private boolean mInitialising;
+
+ private OnDateTimeChangedListener mOnDateTimeChangedListener;
+
+ private NumberPicker.OnValueChangeListener mOnDateChangedListener = new NumberPicker.OnValueChangeListener() {
+ @Override
+ public void onValueChange(NumberPicker picker, int oldVal, int newVal) {
+ mDate.add(Calendar.DAY_OF_YEAR, newVal - oldVal);
+ updateDateControl();
+ onDateTimeChanged();
+ }
+ };
+
+ private NumberPicker.OnValueChangeListener mOnHourChangedListener = new NumberPicker.OnValueChangeListener() {
+ @Override
+ public void onValueChange(NumberPicker picker, int oldVal, int newVal) {
+ boolean isDateChanged = false;
+ Calendar cal = Calendar.getInstance();
+ if (!mIs24HourView) {
+ if (!mIsAm && oldVal == HOURS_IN_HALF_DAY - 1 && newVal == HOURS_IN_HALF_DAY) {
+ cal.setTimeInMillis(mDate.getTimeInMillis());
+ cal.add(Calendar.DAY_OF_YEAR, 1);
+ isDateChanged = true;
+ } else if (mIsAm && oldVal == HOURS_IN_HALF_DAY && newVal == HOURS_IN_HALF_DAY - 1) {
+ cal.setTimeInMillis(mDate.getTimeInMillis());
+ cal.add(Calendar.DAY_OF_YEAR, -1);
+ isDateChanged = true;
+ }
+ if (oldVal == HOURS_IN_HALF_DAY - 1 && newVal == HOURS_IN_HALF_DAY ||
+ oldVal == HOURS_IN_HALF_DAY && newVal == HOURS_IN_HALF_DAY - 1) {
+ mIsAm = !mIsAm;
+ updateAmPmControl();
+ }
+ } else {
+ if (oldVal == HOURS_IN_ALL_DAY - 1 && newVal == 0) {
+ cal.setTimeInMillis(mDate.getTimeInMillis());
+ cal.add(Calendar.DAY_OF_YEAR, 1);
+ isDateChanged = true;
+ } else if (oldVal == 0 && newVal == HOURS_IN_ALL_DAY - 1) {
+ cal.setTimeInMillis(mDate.getTimeInMillis());
+ cal.add(Calendar.DAY_OF_YEAR, -1);
+ isDateChanged = true;
+ }
+ }
+ int newHour = mHourSpinner.getValue() % HOURS_IN_HALF_DAY + (mIsAm ? 0 : HOURS_IN_HALF_DAY);
+ mDate.set(Calendar.HOUR_OF_DAY, newHour);
+ onDateTimeChanged();
+ if (isDateChanged) {
+ setCurrentYear(cal.get(Calendar.YEAR));
+ setCurrentMonth(cal.get(Calendar.MONTH));
+ setCurrentDay(cal.get(Calendar.DAY_OF_MONTH));
+ }
+ }
+ };
+
+ private NumberPicker.OnValueChangeListener mOnMinuteChangedListener = new NumberPicker.OnValueChangeListener() {
+ @Override
+ public void onValueChange(NumberPicker picker, int oldVal, int newVal) {
+ int minValue = mMinuteSpinner.getMinValue();
+ int maxValue = mMinuteSpinner.getMaxValue();
+ int offset = 0;
+ if (oldVal == maxValue && newVal == minValue) {
+ offset += 1;
+ } else if (oldVal == minValue && newVal == maxValue) {
+ offset -= 1;
+ }
+ if (offset != 0) {
+ mDate.add(Calendar.HOUR_OF_DAY, offset);
+ mHourSpinner.setValue(getCurrentHour());
+ updateDateControl();
+ int newHour = getCurrentHourOfDay();
+ if (newHour >= HOURS_IN_HALF_DAY) {
+ mIsAm = false;
+ updateAmPmControl();
+ } else {
+ mIsAm = true;
+ updateAmPmControl();
+ }
+ }
+ mDate.set(Calendar.MINUTE, newVal);
+ onDateTimeChanged();
+ }
+ };
+
+ private NumberPicker.OnValueChangeListener mOnAmPmChangedListener = new NumberPicker.OnValueChangeListener() {
+ @Override
+ public void onValueChange(NumberPicker picker, int oldVal, int newVal) {
+ mIsAm = !mIsAm;
+ if (mIsAm) {
+ mDate.add(Calendar.HOUR_OF_DAY, -HOURS_IN_HALF_DAY);
+ } else {
+ mDate.add(Calendar.HOUR_OF_DAY, HOURS_IN_HALF_DAY);
+ }
+ updateAmPmControl();
+ onDateTimeChanged();
+ }
+ };
+
+ public interface OnDateTimeChangedListener {
+ void onDateTimeChanged(DateTimePicker view, int year, int month,
+ int dayOfMonth, int hourOfDay, int minute);
+ }
+
+ public DateTimePicker(Context context) {
+ this(context, System.currentTimeMillis());
+ }
+
+ public DateTimePicker(Context context, long date) {
+ this(context, date, DateFormat.is24HourFormat(context));
+ }
+
+ public DateTimePicker(Context context, long date, boolean is24HourView) {
+ super(context);
+ mDate = Calendar.getInstance();
+ mInitialising = true;
+ mIsAm = getCurrentHourOfDay() >= HOURS_IN_HALF_DAY;
+ inflate(context, R.layout.datetime_picker, this);
+
+ mDateSpinner = (NumberPicker) findViewById(R.id.date);
+ mDateSpinner.setMinValue(DATE_SPINNER_MIN_VAL);
+ mDateSpinner.setMaxValue(DATE_SPINNER_MAX_VAL);
+ mDateSpinner.setOnValueChangedListener(mOnDateChangedListener);
+
+ mHourSpinner = (NumberPicker) findViewById(R.id.hour);
+ mHourSpinner.setOnValueChangedListener(mOnHourChangedListener);
+ mMinuteSpinner = (NumberPicker) findViewById(R.id.minute);
+ mMinuteSpinner.setMinValue(MINUT_SPINNER_MIN_VAL);
+ mMinuteSpinner.setMaxValue(MINUT_SPINNER_MAX_VAL);
+ mMinuteSpinner.setOnLongPressUpdateInterval(100);
+ mMinuteSpinner.setOnValueChangedListener(mOnMinuteChangedListener);
+
+ String[] stringsForAmPm = new DateFormatSymbols().getAmPmStrings();
+ mAmPmSpinner = (NumberPicker) findViewById(R.id.amPm);
+ mAmPmSpinner.setMinValue(AMPM_SPINNER_MIN_VAL);
+ mAmPmSpinner.setMaxValue(AMPM_SPINNER_MAX_VAL);
+ mAmPmSpinner.setDisplayedValues(stringsForAmPm);
+ mAmPmSpinner.setOnValueChangedListener(mOnAmPmChangedListener);
+
+ // update controls to initial state
+ updateDateControl();
+ updateHourControl();
+ updateAmPmControl();
+
+ set24HourView(is24HourView);
+
+ // set to current time
+ setCurrentDate(date);
+
+ setEnabled(isEnabled());
+
+ // set the content descriptions
+ mInitialising = false;
+ }
+
+ @Override
+ public void setEnabled(boolean enabled) {
+ if (mIsEnabled == enabled) {
+ return;
+ }
+ super.setEnabled(enabled);
+ mDateSpinner.setEnabled(enabled);
+ mMinuteSpinner.setEnabled(enabled);
+ mHourSpinner.setEnabled(enabled);
+ mAmPmSpinner.setEnabled(enabled);
+ mIsEnabled = enabled;
+ }
+
+ @Override
+ public boolean isEnabled() {
+ return mIsEnabled;
+ }
+
+ /**
+ * Get the current date in millis
+ *
+ * @return the current date in millis
+ */
+ public long getCurrentDateInTimeMillis() {
+ return mDate.getTimeInMillis();
+ }
+
+ /**
+ * Set the current date
+ *
+ * @param date The current date in millis
+ */
+ public void setCurrentDate(long date) {
+ Calendar cal = Calendar.getInstance();
+ cal.setTimeInMillis(date);
+ setCurrentDate(cal.get(Calendar.YEAR), cal.get(Calendar.MONTH), cal.get(Calendar.DAY_OF_MONTH),
+ cal.get(Calendar.HOUR_OF_DAY), cal.get(Calendar.MINUTE));
+ }
+
+ /**
+ * Set the current date
+ *
+ * @param year The current year
+ * @param month The current month
+ * @param dayOfMonth The current dayOfMonth
+ * @param hourOfDay The current hourOfDay
+ * @param minute The current minute
+ */
+ public void setCurrentDate(int year, int month,
+ int dayOfMonth, int hourOfDay, int minute) {
+ setCurrentYear(year);
+ setCurrentMonth(month);
+ setCurrentDay(dayOfMonth);
+ setCurrentHour(hourOfDay);
+ setCurrentMinute(minute);
+ }
+
+ /**
+ * Get current year
+ *
+ * @return The current year
+ */
+ public int getCurrentYear() {
+ return mDate.get(Calendar.YEAR);
+ }
+
+ /**
+ * Set current year
+ *
+ * @param year The current year
+ */
+ public void setCurrentYear(int year) {
+ if (!mInitialising && year == getCurrentYear()) {
+ return;
+ }
+ mDate.set(Calendar.YEAR, year);
+ updateDateControl();
+ onDateTimeChanged();
+ }
+
+ /**
+ * Get current month in the year
+ *
+ * @return The current month in the year
+ */
+ public int getCurrentMonth() {
+ return mDate.get(Calendar.MONTH);
+ }
+
+ /**
+ * Set current month in the year
+ *
+ * @param month The month in the year
+ */
+ public void setCurrentMonth(int month) {
+ if (!mInitialising && month == getCurrentMonth()) {
+ return;
+ }
+ mDate.set(Calendar.MONTH, month);
+ updateDateControl();
+ onDateTimeChanged();
+ }
+
+ /**
+ * Get current day of the month
+ *
+ * @return The day of the month
+ */
+ public int getCurrentDay() {
+ return mDate.get(Calendar.DAY_OF_MONTH);
+ }
+
+ /**
+ * Set current day of the month
+ *
+ * @param dayOfMonth The day of the month
+ */
+ public void setCurrentDay(int dayOfMonth) {
+ if (!mInitialising && dayOfMonth == getCurrentDay()) {
+ return;
+ }
+ mDate.set(Calendar.DAY_OF_MONTH, dayOfMonth);
+ updateDateControl();
+ onDateTimeChanged();
+ }
+
+ /**
+ * Get current hour in 24 hour mode, in the range (0~23)
+ * @return The current hour in 24 hour mode
+ */
+ public int getCurrentHourOfDay() {
+ return mDate.get(Calendar.HOUR_OF_DAY);
+ }
+
+ private int getCurrentHour() {
+ if (mIs24HourView){
+ return getCurrentHourOfDay();
+ } else {
+ int hour = getCurrentHourOfDay();
+ if (hour > HOURS_IN_HALF_DAY) {
+ return hour - HOURS_IN_HALF_DAY;
+ } else {
+ return hour == 0 ? HOURS_IN_HALF_DAY : hour;
+ }
+ }
+ }
+
+ /**
+ * Set current hour in 24 hour mode, in the range (0~23)
+ *
+ * @param hourOfDay
+ */
+ public void setCurrentHour(int hourOfDay) {
+ if (!mInitialising && hourOfDay == getCurrentHourOfDay()) {
+ return;
+ }
+ mDate.set(Calendar.HOUR_OF_DAY, hourOfDay);
+ if (!mIs24HourView) {
+ if (hourOfDay >= HOURS_IN_HALF_DAY) {
+ mIsAm = false;
+ if (hourOfDay > HOURS_IN_HALF_DAY) {
+ hourOfDay -= HOURS_IN_HALF_DAY;
+ }
+ } else {
+ mIsAm = true;
+ if (hourOfDay == 0) {
+ hourOfDay = HOURS_IN_HALF_DAY;
+ }
+ }
+ updateAmPmControl();
+ }
+ mHourSpinner.setValue(hourOfDay);
+ onDateTimeChanged();
+ }
+
+ /**
+ * Get currentMinute
+ *
+ * @return The Current Minute
+ */
+ public int getCurrentMinute() {
+ return mDate.get(Calendar.MINUTE);
+ }
+
+ /**
+ * Set current minute
+ */
+ public void setCurrentMinute(int minute) {
+ if (!mInitialising && minute == getCurrentMinute()) {
+ return;
+ }
+ mMinuteSpinner.setValue(minute);
+ mDate.set(Calendar.MINUTE, minute);
+ onDateTimeChanged();
+ }
+
+ /**
+ * @return true if this is in 24 hour view else false.
+ */
+ public boolean is24HourView () {
+ return mIs24HourView;
+ }
+
+ /**
+ * Set whether in 24 hour or AM/PM mode.
+ *
+ * @param is24HourView True for 24 hour mode. False for AM/PM mode.
+ */
+ public void set24HourView(boolean is24HourView) {
+ if (mIs24HourView == is24HourView) {
+ return;
+ }
+ mIs24HourView = is24HourView;
+ mAmPmSpinner.setVisibility(is24HourView ? View.GONE : View.VISIBLE);
+ int hour = getCurrentHourOfDay();
+ updateHourControl();
+ setCurrentHour(hour);
+ updateAmPmControl();
+ }
+
+ private void updateDateControl() {
+ Calendar cal = Calendar.getInstance();
+ cal.setTimeInMillis(mDate.getTimeInMillis());
+ cal.add(Calendar.DAY_OF_YEAR, -DAYS_IN_ALL_WEEK / 2 - 1);
+ mDateSpinner.setDisplayedValues(null);
+ for (int i = 0; i < DAYS_IN_ALL_WEEK; ++i) {
+ cal.add(Calendar.DAY_OF_YEAR, 1);
+ mDateDisplayValues[i] = (String) DateFormat.format("MM.dd EEEE", cal);
+ }
+ mDateSpinner.setDisplayedValues(mDateDisplayValues);
+ mDateSpinner.setValue(DAYS_IN_ALL_WEEK / 2);
+ mDateSpinner.invalidate();
+ }
+
+ private void updateAmPmControl() {
+ if (mIs24HourView) {
+ mAmPmSpinner.setVisibility(View.GONE);
+ } else {
+ int index = mIsAm ? Calendar.AM : Calendar.PM;
+ mAmPmSpinner.setValue(index);
+ mAmPmSpinner.setVisibility(View.VISIBLE);
+ }
+ }
+
+ private void updateHourControl() {
+ if (mIs24HourView) {
+ mHourSpinner.setMinValue(HOUR_SPINNER_MIN_VAL_24_HOUR_VIEW);
+ mHourSpinner.setMaxValue(HOUR_SPINNER_MAX_VAL_24_HOUR_VIEW);
+ } else {
+ mHourSpinner.setMinValue(HOUR_SPINNER_MIN_VAL_12_HOUR_VIEW);
+ mHourSpinner.setMaxValue(HOUR_SPINNER_MAX_VAL_12_HOUR_VIEW);
+ }
+ }
+
+ /**
+ * Set the callback that indicates the 'Set' button has been pressed.
+ * @param callback the callback, if null will do nothing
+ */
+ public void setOnDateTimeChangedListener(OnDateTimeChangedListener callback) {
+ mOnDateTimeChangedListener = callback;
+ }
+
+ private void onDateTimeChanged() {
+ if (mOnDateTimeChangedListener != null) {
+ mOnDateTimeChangedListener.onDateTimeChanged(this, getCurrentYear(),
+ getCurrentMonth(), getCurrentDay(), getCurrentHourOfDay(), getCurrentMinute());
+ }
+ }
+}
diff --git a/src/src/Notes-master/src/net/micode/notes/ui/DateTimePickerDialog.java b/src/src/Notes-master/src/net/micode/notes/ui/DateTimePickerDialog.java
new file mode 100644
index 0000000..2c47ba4
--- /dev/null
+++ b/src/src/Notes-master/src/net/micode/notes/ui/DateTimePickerDialog.java
@@ -0,0 +1,90 @@
+/*
+ * Copyright (c) 2010-2011, The MiCode Open Source Community (www.micode.net)
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+
+package net.micode.notes.ui;
+
+import java.util.Calendar;
+
+import net.micode.notes.R;
+import net.micode.notes.ui.DateTimePicker;
+import net.micode.notes.ui.DateTimePicker.OnDateTimeChangedListener;
+
+import android.app.AlertDialog;
+import android.content.Context;
+import android.content.DialogInterface;
+import android.content.DialogInterface.OnClickListener;
+import android.text.format.DateFormat;
+import android.text.format.DateUtils;
+
+public class DateTimePickerDialog extends AlertDialog implements OnClickListener {
+
+ private Calendar mDate = Calendar.getInstance();
+ private boolean mIs24HourView;
+ private OnDateTimeSetListener mOnDateTimeSetListener;
+ private DateTimePicker mDateTimePicker;
+
+ public interface OnDateTimeSetListener {
+ void OnDateTimeSet(AlertDialog dialog, long date);
+ }
+
+ public DateTimePickerDialog(Context context, long date) {
+ super(context);
+ mDateTimePicker = new DateTimePicker(context);
+ setView(mDateTimePicker);
+ mDateTimePicker.setOnDateTimeChangedListener(new OnDateTimeChangedListener() {
+ public void onDateTimeChanged(DateTimePicker view, int year, int month,
+ int dayOfMonth, int hourOfDay, int minute) {
+ mDate.set(Calendar.YEAR, year);
+ mDate.set(Calendar.MONTH, month);
+ mDate.set(Calendar.DAY_OF_MONTH, dayOfMonth);
+ mDate.set(Calendar.HOUR_OF_DAY, hourOfDay);
+ mDate.set(Calendar.MINUTE, minute);
+ updateTitle(mDate.getTimeInMillis());
+ }
+ });
+ mDate.setTimeInMillis(date);
+ mDate.set(Calendar.SECOND, 0);
+ mDateTimePicker.setCurrentDate(mDate.getTimeInMillis());
+ setButton(context.getString(R.string.datetime_dialog_ok), this);
+ setButton2(context.getString(R.string.datetime_dialog_cancel), (OnClickListener)null);
+ set24HourView(DateFormat.is24HourFormat(this.getContext()));
+ updateTitle(mDate.getTimeInMillis());
+ }
+
+ public void set24HourView(boolean is24HourView) {
+ mIs24HourView = is24HourView;
+ }
+
+ public void setOnDateTimeSetListener(OnDateTimeSetListener callBack) {
+ mOnDateTimeSetListener = callBack;
+ }
+
+ private void updateTitle(long date) {
+ int flag =
+ DateUtils.FORMAT_SHOW_YEAR |
+ DateUtils.FORMAT_SHOW_DATE |
+ DateUtils.FORMAT_SHOW_TIME;
+ flag |= mIs24HourView ? DateUtils.FORMAT_24HOUR : DateUtils.FORMAT_24HOUR;
+ setTitle(DateUtils.formatDateTime(this.getContext(), date, flag));
+ }
+
+ public void onClick(DialogInterface arg0, int arg1) {
+ if (mOnDateTimeSetListener != null) {
+ mOnDateTimeSetListener.OnDateTimeSet(this, mDate.getTimeInMillis());
+ }
+ }
+
+}
\ No newline at end of file
diff --git a/src/src/Notes-master/src/net/micode/notes/ui/DropdownMenu.java b/src/src/Notes-master/src/net/micode/notes/ui/DropdownMenu.java
new file mode 100644
index 0000000..613dc74
--- /dev/null
+++ b/src/src/Notes-master/src/net/micode/notes/ui/DropdownMenu.java
@@ -0,0 +1,61 @@
+/*
+ * Copyright (c) 2010-2011, The MiCode Open Source Community (www.micode.net)
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+
+package net.micode.notes.ui;
+
+import android.content.Context;
+import android.view.Menu;
+import android.view.MenuItem;
+import android.view.View;
+import android.view.View.OnClickListener;
+import android.widget.Button;
+import android.widget.PopupMenu;
+import android.widget.PopupMenu.OnMenuItemClickListener;
+
+import net.micode.notes.R;
+
+public class DropdownMenu {
+ private Button mButton;
+ private PopupMenu mPopupMenu;
+ private Menu mMenu;
+
+ public DropdownMenu(Context context, Button button, int menuId) {
+ mButton = button;
+ mButton.setBackgroundResource(R.drawable.dropdown_icon);
+ mPopupMenu = new PopupMenu(context, mButton);
+ mMenu = mPopupMenu.getMenu();
+ mPopupMenu.getMenuInflater().inflate(menuId, mMenu);
+ mButton.setOnClickListener(new OnClickListener() {
+ public void onClick(View v) {
+ mPopupMenu.show();
+ }
+ });
+ }
+
+ public void setOnDropdownMenuItemClickListener(OnMenuItemClickListener listener) {
+ if (mPopupMenu != null) {
+ mPopupMenu.setOnMenuItemClickListener(listener);
+ }
+ }
+
+ public MenuItem findItem(int id) {
+ return mMenu.findItem(id);
+ }
+
+ public void setTitle(CharSequence title) {
+ mButton.setText(title);
+ }
+}
diff --git a/src/src/Notes-master/src/net/micode/notes/ui/FoldersListAdapter.java b/src/src/Notes-master/src/net/micode/notes/ui/FoldersListAdapter.java
new file mode 100644
index 0000000..96b77da
--- /dev/null
+++ b/src/src/Notes-master/src/net/micode/notes/ui/FoldersListAdapter.java
@@ -0,0 +1,80 @@
+/*
+ * Copyright (c) 2010-2011, The MiCode Open Source Community (www.micode.net)
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+
+package net.micode.notes.ui;
+
+import android.content.Context;
+import android.database.Cursor;
+import android.view.View;
+import android.view.ViewGroup;
+import android.widget.CursorAdapter;
+import android.widget.LinearLayout;
+import android.widget.TextView;
+
+import net.micode.notes.R;
+import net.micode.notes.data.Notes;
+import net.micode.notes.data.Notes.NoteColumns;
+
+
+public class FoldersListAdapter extends CursorAdapter {
+ public static final String [] PROJECTION = {
+ NoteColumns.ID,
+ NoteColumns.SNIPPET
+ };
+
+ public static final int ID_COLUMN = 0;
+ public static final int NAME_COLUMN = 1;
+
+ public FoldersListAdapter(Context context, Cursor c) {
+ super(context, c);
+ // TODO Auto-generated constructor stub
+ }
+
+ @Override
+ public View newView(Context context, Cursor cursor, ViewGroup parent) {
+ return new FolderListItem(context);
+ }
+
+ @Override
+ public void bindView(View view, Context context, Cursor cursor) {
+ if (view instanceof FolderListItem) {
+ String folderName = (cursor.getLong(ID_COLUMN) == Notes.ID_ROOT_FOLDER) ? context
+ .getString(R.string.menu_move_parent_folder) : cursor.getString(NAME_COLUMN);
+ ((FolderListItem) view).bind(folderName);
+ }
+ }
+
+ public String getFolderName(Context context, int position) {
+ Cursor cursor = (Cursor) getItem(position);
+ return (cursor.getLong(ID_COLUMN) == Notes.ID_ROOT_FOLDER) ? context
+ .getString(R.string.menu_move_parent_folder) : cursor.getString(NAME_COLUMN);
+ }
+
+ private class FolderListItem extends LinearLayout {
+ private TextView mName;
+
+ public FolderListItem(Context context) {
+ super(context);
+ inflate(context, R.layout.folder_list_item, this);
+ mName = (TextView) findViewById(R.id.tv_folder_name);
+ }
+
+ public void bind(String name) {
+ mName.setText(name);
+ }
+ }
+
+}
diff --git a/src/src/Notes-master/src/net/micode/notes/ui/NoteEditActivity.java b/src/src/Notes-master/src/net/micode/notes/ui/NoteEditActivity.java
new file mode 100644
index 0000000..96a9ff8
--- /dev/null
+++ b/src/src/Notes-master/src/net/micode/notes/ui/NoteEditActivity.java
@@ -0,0 +1,873 @@
+/*
+ * Copyright (c) 2010-2011, The MiCode Open Source Community (www.micode.net)
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+
+package net.micode.notes.ui;
+
+import android.app.Activity;
+import android.app.AlarmManager;
+import android.app.AlertDialog;
+import android.app.PendingIntent;
+import android.app.SearchManager;
+import android.appwidget.AppWidgetManager;
+import android.content.ContentUris;
+import android.content.Context;
+import android.content.DialogInterface;
+import android.content.Intent;
+import android.content.SharedPreferences;
+import android.graphics.Paint;
+import android.os.Bundle;
+import android.preference.PreferenceManager;
+import android.text.Spannable;
+import android.text.SpannableString;
+import android.text.TextUtils;
+import android.text.format.DateUtils;
+import android.text.style.BackgroundColorSpan;
+import android.util.Log;
+import android.view.LayoutInflater;
+import android.view.Menu;
+import android.view.MenuItem;
+import android.view.MotionEvent;
+import android.view.View;
+import android.view.View.OnClickListener;
+import android.view.WindowManager;
+import android.widget.CheckBox;
+import android.widget.CompoundButton;
+import android.widget.CompoundButton.OnCheckedChangeListener;
+import android.widget.EditText;
+import android.widget.ImageView;
+import android.widget.LinearLayout;
+import android.widget.TextView;
+import android.widget.Toast;
+
+import net.micode.notes.R;
+import net.micode.notes.data.Notes;
+import net.micode.notes.data.Notes.TextNote;
+import net.micode.notes.model.WorkingNote;
+import net.micode.notes.model.WorkingNote.NoteSettingChangedListener;
+import net.micode.notes.tool.DataUtils;
+import net.micode.notes.tool.ResourceParser;
+import net.micode.notes.tool.ResourceParser.TextAppearanceResources;
+import net.micode.notes.ui.DateTimePickerDialog.OnDateTimeSetListener;
+import net.micode.notes.ui.NoteEditText.OnTextViewChangeListener;
+import net.micode.notes.widget.NoteWidgetProvider_2x;
+import net.micode.notes.widget.NoteWidgetProvider_4x;
+
+import java.util.HashMap;
+import java.util.HashSet;
+import java.util.Map;
+import java.util.regex.Matcher;
+import java.util.regex.Pattern;
+
+
+public class NoteEditActivity extends Activity implements OnClickListener,
+ NoteSettingChangedListener, OnTextViewChangeListener {
+ private class HeadViewHolder {
+ public TextView tvModified;
+
+ public ImageView ivAlertIcon;
+
+ public TextView tvAlertDate;
+
+ public ImageView ibSetBgColor;
+ }
+
+ private static final Map sBgSelectorBtnsMap = new HashMap();
+ static {
+ sBgSelectorBtnsMap.put(R.id.iv_bg_yellow, ResourceParser.YELLOW);
+ sBgSelectorBtnsMap.put(R.id.iv_bg_red, ResourceParser.RED);
+ sBgSelectorBtnsMap.put(R.id.iv_bg_blue, ResourceParser.BLUE);
+ sBgSelectorBtnsMap.put(R.id.iv_bg_green, ResourceParser.GREEN);
+ sBgSelectorBtnsMap.put(R.id.iv_bg_white, ResourceParser.WHITE);
+ }
+
+ private static final Map sBgSelectorSelectionMap = new HashMap();
+ static {
+ sBgSelectorSelectionMap.put(ResourceParser.YELLOW, R.id.iv_bg_yellow_select);
+ sBgSelectorSelectionMap.put(ResourceParser.RED, R.id.iv_bg_red_select);
+ sBgSelectorSelectionMap.put(ResourceParser.BLUE, R.id.iv_bg_blue_select);
+ sBgSelectorSelectionMap.put(ResourceParser.GREEN, R.id.iv_bg_green_select);
+ sBgSelectorSelectionMap.put(ResourceParser.WHITE, R.id.iv_bg_white_select);
+ }
+
+ private static final Map sFontSizeBtnsMap = new HashMap();
+ static {
+ sFontSizeBtnsMap.put(R.id.ll_font_large, ResourceParser.TEXT_LARGE);
+ sFontSizeBtnsMap.put(R.id.ll_font_small, ResourceParser.TEXT_SMALL);
+ sFontSizeBtnsMap.put(R.id.ll_font_normal, ResourceParser.TEXT_MEDIUM);
+ sFontSizeBtnsMap.put(R.id.ll_font_super, ResourceParser.TEXT_SUPER);
+ }
+
+ private static final Map sFontSelectorSelectionMap = new HashMap();
+ static {
+ sFontSelectorSelectionMap.put(ResourceParser.TEXT_LARGE, R.id.iv_large_select);
+ sFontSelectorSelectionMap.put(ResourceParser.TEXT_SMALL, R.id.iv_small_select);
+ sFontSelectorSelectionMap.put(ResourceParser.TEXT_MEDIUM, R.id.iv_medium_select);
+ sFontSelectorSelectionMap.put(ResourceParser.TEXT_SUPER, R.id.iv_super_select);
+ }
+
+ private static final String TAG = "NoteEditActivity";
+
+ private HeadViewHolder mNoteHeaderHolder;
+
+ private View mHeadViewPanel;
+
+ private View mNoteBgColorSelector;
+
+ private View mFontSizeSelector;
+
+ private EditText mNoteEditor;
+
+ private View mNoteEditorPanel;
+
+ private WorkingNote mWorkingNote;
+
+ private SharedPreferences mSharedPrefs;
+ private int mFontSizeId;
+
+ private static final String PREFERENCE_FONT_SIZE = "pref_font_size";
+
+ private static final int SHORTCUT_ICON_TITLE_MAX_LEN = 10;
+
+ public static final String TAG_CHECKED = String.valueOf('\u221A');
+ public static final String TAG_UNCHECKED = String.valueOf('\u25A1');
+
+ private LinearLayout mEditTextList;
+
+ private String mUserQuery;
+ private Pattern mPattern;
+
+ @Override
+ protected void onCreate(Bundle savedInstanceState) {
+ super.onCreate(savedInstanceState);
+ this.setContentView(R.layout.note_edit);
+
+ if (savedInstanceState == null && !initActivityState(getIntent())) {
+ finish();
+ return;
+ }
+ initResources();
+ }
+
+ /**
+ * Current activity may be killed when the memory is low. Once it is killed, for another time
+ * user load this activity, we should restore the former state
+ */
+ @Override
+ protected void onRestoreInstanceState(Bundle savedInstanceState) {
+ super.onRestoreInstanceState(savedInstanceState);
+ if (savedInstanceState != null && savedInstanceState.containsKey(Intent.EXTRA_UID)) {
+ Intent intent = new Intent(Intent.ACTION_VIEW);
+ intent.putExtra(Intent.EXTRA_UID, savedInstanceState.getLong(Intent.EXTRA_UID));
+ if (!initActivityState(intent)) {
+ finish();
+ return;
+ }
+ Log.d(TAG, "Restoring from killed activity");
+ }
+ }
+
+ private boolean initActivityState(Intent intent) {
+ /**
+ * If the user specified the {@link Intent#ACTION_VIEW} but not provided with id,
+ * then jump to the NotesListActivity
+ */
+ mWorkingNote = null;
+ if (TextUtils.equals(Intent.ACTION_VIEW, intent.getAction())) {
+ long noteId = intent.getLongExtra(Intent.EXTRA_UID, 0);
+ mUserQuery = "";
+
+ /**
+ * Starting from the searched result
+ */
+ if (intent.hasExtra(SearchManager.EXTRA_DATA_KEY)) {
+ noteId = Long.parseLong(intent.getStringExtra(SearchManager.EXTRA_DATA_KEY));
+ mUserQuery = intent.getStringExtra(SearchManager.USER_QUERY);
+ }
+
+ if (!DataUtils.visibleInNoteDatabase(getContentResolver(), noteId, Notes.TYPE_NOTE)) {
+ Intent jump = new Intent(this, NotesListActivity.class);
+ startActivity(jump);
+ showToast(R.string.error_note_not_exist);
+ finish();
+ return false;
+ } else {
+ mWorkingNote = WorkingNote.load(this, noteId);
+ if (mWorkingNote == null) {
+ Log.e(TAG, "load note failed with note id" + noteId);
+ finish();
+ return false;
+ }
+ }
+ getWindow().setSoftInputMode(
+ WindowManager.LayoutParams.SOFT_INPUT_STATE_HIDDEN
+ | WindowManager.LayoutParams.SOFT_INPUT_ADJUST_RESIZE);
+ } else if(TextUtils.equals(Intent.ACTION_INSERT_OR_EDIT, intent.getAction())) {
+ // New note
+ long folderId = intent.getLongExtra(Notes.INTENT_EXTRA_FOLDER_ID, 0);
+ int widgetId = intent.getIntExtra(Notes.INTENT_EXTRA_WIDGET_ID,
+ AppWidgetManager.INVALID_APPWIDGET_ID);
+ int widgetType = intent.getIntExtra(Notes.INTENT_EXTRA_WIDGET_TYPE,
+ Notes.TYPE_WIDGET_INVALIDE);
+ int bgResId = intent.getIntExtra(Notes.INTENT_EXTRA_BACKGROUND_ID,
+ ResourceParser.getDefaultBgId(this));
+
+ // Parse call-record note
+ String phoneNumber = intent.getStringExtra(Intent.EXTRA_PHONE_NUMBER);
+ long callDate = intent.getLongExtra(Notes.INTENT_EXTRA_CALL_DATE, 0);
+ if (callDate != 0 && phoneNumber != null) {
+ if (TextUtils.isEmpty(phoneNumber)) {
+ Log.w(TAG, "The call record number is null");
+ }
+ long noteId = 0;
+ if ((noteId = DataUtils.getNoteIdByPhoneNumberAndCallDate(getContentResolver(),
+ phoneNumber, callDate)) > 0) {
+ mWorkingNote = WorkingNote.load(this, noteId);
+ if (mWorkingNote == null) {
+ Log.e(TAG, "load call note failed with note id" + noteId);
+ finish();
+ return false;
+ }
+ } else {
+ mWorkingNote = WorkingNote.createEmptyNote(this, folderId, widgetId,
+ widgetType, bgResId);
+ mWorkingNote.convertToCallNote(phoneNumber, callDate);
+ }
+ } else {
+ mWorkingNote = WorkingNote.createEmptyNote(this, folderId, widgetId, widgetType,
+ bgResId);
+ }
+
+ getWindow().setSoftInputMode(
+ WindowManager.LayoutParams.SOFT_INPUT_ADJUST_RESIZE
+ | WindowManager.LayoutParams.SOFT_INPUT_STATE_VISIBLE);
+ } else {
+ Log.e(TAG, "Intent not specified action, should not support");
+ finish();
+ return false;
+ }
+ mWorkingNote.setOnSettingStatusChangedListener(this);
+ return true;
+ }
+
+ @Override
+ protected void onResume() {
+ super.onResume();
+ initNoteScreen();
+ }
+
+ private void initNoteScreen() {
+ mNoteEditor.setTextAppearance(this, TextAppearanceResources
+ .getTexAppearanceResource(mFontSizeId));
+ if (mWorkingNote.getCheckListMode() == TextNote.MODE_CHECK_LIST) {
+ switchToListMode(mWorkingNote.getContent());
+ } else {
+ mNoteEditor.setText(getHighlightQueryResult(mWorkingNote.getContent(), mUserQuery));
+ mNoteEditor.setSelection(mNoteEditor.getText().length());
+ }
+ for (Integer id : sBgSelectorSelectionMap.keySet()) {
+ findViewById(sBgSelectorSelectionMap.get(id)).setVisibility(View.GONE);
+ }
+ mHeadViewPanel.setBackgroundResource(mWorkingNote.getTitleBgResId());
+ mNoteEditorPanel.setBackgroundResource(mWorkingNote.getBgColorResId());
+
+ mNoteHeaderHolder.tvModified.setText(DateUtils.formatDateTime(this,
+ mWorkingNote.getModifiedDate(), DateUtils.FORMAT_SHOW_DATE
+ | DateUtils.FORMAT_NUMERIC_DATE | DateUtils.FORMAT_SHOW_TIME
+ | DateUtils.FORMAT_SHOW_YEAR));
+
+ /**
+ * TODO: Add the menu for setting alert. Currently disable it because the DateTimePicker
+ * is not ready
+ */
+ showAlertHeader();
+ }
+
+ private void showAlertHeader() {
+ if (mWorkingNote.hasClockAlert()) {
+ long time = System.currentTimeMillis();
+ if (time > mWorkingNote.getAlertDate()) {
+ mNoteHeaderHolder.tvAlertDate.setText(R.string.note_alert_expired);
+ } else {
+ mNoteHeaderHolder.tvAlertDate.setText(DateUtils.getRelativeTimeSpanString(
+ mWorkingNote.getAlertDate(), time, DateUtils.MINUTE_IN_MILLIS));
+ }
+ mNoteHeaderHolder.tvAlertDate.setVisibility(View.VISIBLE);
+ mNoteHeaderHolder.ivAlertIcon.setVisibility(View.VISIBLE);
+ } else {
+ mNoteHeaderHolder.tvAlertDate.setVisibility(View.GONE);
+ mNoteHeaderHolder.ivAlertIcon.setVisibility(View.GONE);
+ };
+ }
+
+ @Override
+ protected void onNewIntent(Intent intent) {
+ super.onNewIntent(intent);
+ initActivityState(intent);
+ }
+
+ @Override
+ protected void onSaveInstanceState(Bundle outState) {
+ super.onSaveInstanceState(outState);
+ /**
+ * For new note without note id, we should firstly save it to
+ * generate a id. If the editing note is not worth saving, there
+ * is no id which is equivalent to create new note
+ */
+ if (!mWorkingNote.existInDatabase()) {
+ saveNote();
+ }
+ outState.putLong(Intent.EXTRA_UID, mWorkingNote.getNoteId());
+ Log.d(TAG, "Save working note id: " + mWorkingNote.getNoteId() + " onSaveInstanceState");
+ }
+
+ @Override
+ public boolean dispatchTouchEvent(MotionEvent ev) {
+ if (mNoteBgColorSelector.getVisibility() == View.VISIBLE
+ && !inRangeOfView(mNoteBgColorSelector, ev)) {
+ mNoteBgColorSelector.setVisibility(View.GONE);
+ return true;
+ }
+
+ if (mFontSizeSelector.getVisibility() == View.VISIBLE
+ && !inRangeOfView(mFontSizeSelector, ev)) {
+ mFontSizeSelector.setVisibility(View.GONE);
+ return true;
+ }
+ return super.dispatchTouchEvent(ev);
+ }
+
+ private boolean inRangeOfView(View view, MotionEvent ev) {
+ int []location = new int[2];
+ view.getLocationOnScreen(location);
+ int x = location[0];
+ int y = location[1];
+ if (ev.getX() < x
+ || ev.getX() > (x + view.getWidth())
+ || ev.getY() < y
+ || ev.getY() > (y + view.getHeight())) {
+ return false;
+ }
+ return true;
+ }
+
+ private void initResources() {
+ mHeadViewPanel = findViewById(R.id.note_title);
+ mNoteHeaderHolder = new HeadViewHolder();
+ mNoteHeaderHolder.tvModified = (TextView) findViewById(R.id.tv_modified_date);
+ mNoteHeaderHolder.ivAlertIcon = (ImageView) findViewById(R.id.iv_alert_icon);
+ mNoteHeaderHolder.tvAlertDate = (TextView) findViewById(R.id.tv_alert_date);
+ mNoteHeaderHolder.ibSetBgColor = (ImageView) findViewById(R.id.btn_set_bg_color);
+ mNoteHeaderHolder.ibSetBgColor.setOnClickListener(this);
+ mNoteEditor = (EditText) findViewById(R.id.note_edit_view);
+ mNoteEditorPanel = findViewById(R.id.sv_note_edit);
+ mNoteBgColorSelector = findViewById(R.id.note_bg_color_selector);
+ for (int id : sBgSelectorBtnsMap.keySet()) {
+ ImageView iv = (ImageView) findViewById(id);
+ iv.setOnClickListener(this);
+ }
+
+ mFontSizeSelector = findViewById(R.id.font_size_selector);
+ for (int id : sFontSizeBtnsMap.keySet()) {
+ View view = findViewById(id);
+ view.setOnClickListener(this);
+ };
+ mSharedPrefs = PreferenceManager.getDefaultSharedPreferences(this);
+ mFontSizeId = mSharedPrefs.getInt(PREFERENCE_FONT_SIZE, ResourceParser.BG_DEFAULT_FONT_SIZE);
+ /**
+ * HACKME: Fix bug of store the resource id in shared preference.
+ * The id may larger than the length of resources, in this case,
+ * return the {@link ResourceParser#BG_DEFAULT_FONT_SIZE}
+ */
+ if(mFontSizeId >= TextAppearanceResources.getResourcesSize()) {
+ mFontSizeId = ResourceParser.BG_DEFAULT_FONT_SIZE;
+ }
+ mEditTextList = (LinearLayout) findViewById(R.id.note_edit_list);
+ }
+
+ @Override
+ protected void onPause() {
+ super.onPause();
+ if(saveNote()) {
+ Log.d(TAG, "Note data was saved with length:" + mWorkingNote.getContent().length());
+ }
+ clearSettingState();
+ }
+
+ private void updateWidget() {
+ Intent intent = new Intent(AppWidgetManager.ACTION_APPWIDGET_UPDATE);
+ if (mWorkingNote.getWidgetType() == Notes.TYPE_WIDGET_2X) {
+ intent.setClass(this, NoteWidgetProvider_2x.class);
+ } else if (mWorkingNote.getWidgetType() == Notes.TYPE_WIDGET_4X) {
+ intent.setClass(this, NoteWidgetProvider_4x.class);
+ } else {
+ Log.e(TAG, "Unspported widget type");
+ return;
+ }
+
+ intent.putExtra(AppWidgetManager.EXTRA_APPWIDGET_IDS, new int[] {
+ mWorkingNote.getWidgetId()
+ });
+
+ sendBroadcast(intent);
+ setResult(RESULT_OK, intent);
+ }
+
+ public void onClick(View v) {
+ int id = v.getId();
+ if (id == R.id.btn_set_bg_color) {
+ mNoteBgColorSelector.setVisibility(View.VISIBLE);
+ findViewById(sBgSelectorSelectionMap.get(mWorkingNote.getBgColorId())).setVisibility(
+ - View.VISIBLE);
+ } else if (sBgSelectorBtnsMap.containsKey(id)) {
+ findViewById(sBgSelectorSelectionMap.get(mWorkingNote.getBgColorId())).setVisibility(
+ View.GONE);
+ mWorkingNote.setBgColorId(sBgSelectorBtnsMap.get(id));
+ mNoteBgColorSelector.setVisibility(View.GONE);
+ } else if (sFontSizeBtnsMap.containsKey(id)) {
+ findViewById(sFontSelectorSelectionMap.get(mFontSizeId)).setVisibility(View.GONE);
+ mFontSizeId = sFontSizeBtnsMap.get(id);
+ mSharedPrefs.edit().putInt(PREFERENCE_FONT_SIZE, mFontSizeId).commit();
+ findViewById(sFontSelectorSelectionMap.get(mFontSizeId)).setVisibility(View.VISIBLE);
+ if (mWorkingNote.getCheckListMode() == TextNote.MODE_CHECK_LIST) {
+ getWorkingText();
+ switchToListMode(mWorkingNote.getContent());
+ } else {
+ mNoteEditor.setTextAppearance(this,
+ TextAppearanceResources.getTexAppearanceResource(mFontSizeId));
+ }
+ mFontSizeSelector.setVisibility(View.GONE);
+ }
+ }
+
+ @Override
+ public void onBackPressed() {
+ if(clearSettingState()) {
+ return;
+ }
+
+ saveNote();
+ super.onBackPressed();
+ }
+
+ private boolean clearSettingState() {
+ if (mNoteBgColorSelector.getVisibility() == View.VISIBLE) {
+ mNoteBgColorSelector.setVisibility(View.GONE);
+ return true;
+ } else if (mFontSizeSelector.getVisibility() == View.VISIBLE) {
+ mFontSizeSelector.setVisibility(View.GONE);
+ return true;
+ }
+ return false;
+ }
+
+ public void onBackgroundColorChanged() {
+ findViewById(sBgSelectorSelectionMap.get(mWorkingNote.getBgColorId())).setVisibility(
+ View.VISIBLE);
+ mNoteEditorPanel.setBackgroundResource(mWorkingNote.getBgColorResId());
+ mHeadViewPanel.setBackgroundResource(mWorkingNote.getTitleBgResId());
+ }
+
+ @Override
+ public boolean onPrepareOptionsMenu(Menu menu) {
+ if (isFinishing()) {
+ return true;
+ }
+ clearSettingState();
+ menu.clear();
+ if (mWorkingNote.getFolderId() == Notes.ID_CALL_RECORD_FOLDER) {
+ getMenuInflater().inflate(R.menu.call_note_edit, menu);
+ } else {
+ getMenuInflater().inflate(R.menu.note_edit, menu);
+ }
+ if (mWorkingNote.getCheckListMode() == TextNote.MODE_CHECK_LIST) {
+ menu.findItem(R.id.menu_list_mode).setTitle(R.string.menu_normal_mode);
+ } else {
+ menu.findItem(R.id.menu_list_mode).setTitle(R.string.menu_list_mode);
+ }
+ if (mWorkingNote.hasClockAlert()) {
+ menu.findItem(R.id.menu_alert).setVisible(false);
+ } else {
+ menu.findItem(R.id.menu_delete_remind).setVisible(false);
+ }
+ return true;
+ }
+
+ @Override
+ public boolean onOptionsItemSelected(MenuItem item) {
+ switch (item.getItemId()) {
+ case R.id.menu_new_note:
+ createNewNote();
+ break;
+ case R.id.menu_delete:
+ AlertDialog.Builder builder = new AlertDialog.Builder(this);
+ builder.setTitle(getString(R.string.alert_title_delete));
+ builder.setIcon(android.R.drawable.ic_dialog_alert);
+ builder.setMessage(getString(R.string.alert_message_delete_note));
+ builder.setPositiveButton(android.R.string.ok,
+ new DialogInterface.OnClickListener() {
+ public void onClick(DialogInterface dialog, int which) {
+ deleteCurrentNote();
+ finish();
+ }
+ });
+ builder.setNegativeButton(android.R.string.cancel, null);
+ builder.show();
+ break;
+ case R.id.menu_font_size:
+ mFontSizeSelector.setVisibility(View.VISIBLE);
+ findViewById(sFontSelectorSelectionMap.get(mFontSizeId)).setVisibility(View.VISIBLE);
+ break;
+ case R.id.menu_list_mode:
+ mWorkingNote.setCheckListMode(mWorkingNote.getCheckListMode() == 0 ?
+ TextNote.MODE_CHECK_LIST : 0);
+ break;
+ case R.id.menu_share:
+ getWorkingText();
+ sendTo(this, mWorkingNote.getContent());
+ break;
+ case R.id.menu_send_to_desktop:
+ sendToDesktop();
+ break;
+ case R.id.menu_alert:
+ setReminder();
+ break;
+ case R.id.menu_delete_remind:
+ mWorkingNote.setAlertDate(0, false);
+ break;
+ default:
+ break;
+ }
+ return true;
+ }
+
+ private void setReminder() {
+ DateTimePickerDialog d = new DateTimePickerDialog(this, System.currentTimeMillis());
+ d.setOnDateTimeSetListener(new OnDateTimeSetListener() {
+ public void OnDateTimeSet(AlertDialog dialog, long date) {
+ mWorkingNote.setAlertDate(date , true);
+ }
+ });
+ d.show();
+ }
+
+ /**
+ * Share note to apps that support {@link Intent#ACTION_SEND} action
+ * and {@text/plain} type
+ */
+ private void sendTo(Context context, String info) {
+ Intent intent = new Intent(Intent.ACTION_SEND);
+ intent.putExtra(Intent.EXTRA_TEXT, info);
+ intent.setType("text/plain");
+ context.startActivity(intent);
+ }
+
+ private void createNewNote() {
+ // Firstly, save current editing notes
+ saveNote();
+
+ // For safety, start a new NoteEditActivity
+ finish();
+ Intent intent = new Intent(this, NoteEditActivity.class);
+ intent.setAction(Intent.ACTION_INSERT_OR_EDIT);
+ intent.putExtra(Notes.INTENT_EXTRA_FOLDER_ID, mWorkingNote.getFolderId());
+ startActivity(intent);
+ }
+
+ private void deleteCurrentNote() {
+ if (mWorkingNote.existInDatabase()) {
+ HashSet ids = new HashSet();
+ long id = mWorkingNote.getNoteId();
+ if (id != Notes.ID_ROOT_FOLDER) {
+ ids.add(id);
+ } else {
+ Log.d(TAG, "Wrong note id, should not happen");
+ }
+ if (!isSyncMode()) {
+ if (!DataUtils.batchDeleteNotes(getContentResolver(), ids)) {
+ Log.e(TAG, "Delete Note error");
+ }
+ } else {
+ if (!DataUtils.batchMoveToFolder(getContentResolver(), ids, Notes.ID_TRASH_FOLER)) {
+ Log.e(TAG, "Move notes to trash folder error, should not happens");
+ }
+ }
+ }
+ mWorkingNote.markDeleted(true);
+ }
+
+ private boolean isSyncMode() {
+ return NotesPreferenceActivity.getSyncAccountName(this).trim().length() > 0;
+ }
+
+ public void onClockAlertChanged(long date, boolean set) {
+ /**
+ * User could set clock to an unsaved note, so before setting the
+ * alert clock, we should save the note first
+ */
+ if (!mWorkingNote.existInDatabase()) {
+ saveNote();
+ }
+ if (mWorkingNote.getNoteId() > 0) {
+ Intent intent = new Intent(this, AlarmReceiver.class);
+ intent.setData(ContentUris.withAppendedId(Notes.CONTENT_NOTE_URI, mWorkingNote.getNoteId()));
+ PendingIntent pendingIntent = PendingIntent.getBroadcast(this, 0, intent, 0);
+ AlarmManager alarmManager = ((AlarmManager) getSystemService(ALARM_SERVICE));
+ showAlertHeader();
+ if(!set) {
+ alarmManager.cancel(pendingIntent);
+ } else {
+ alarmManager.set(AlarmManager.RTC_WAKEUP, date, pendingIntent);
+ }
+ } else {
+ /**
+ * There is the condition that user has input nothing (the note is
+ * not worthy saving), we have no note id, remind the user that he
+ * should input something
+ */
+ Log.e(TAG, "Clock alert setting error");
+ showToast(R.string.error_note_empty_for_clock);
+ }
+ }
+
+ public void onWidgetChanged() {
+ updateWidget();
+ }
+
+ public void onEditTextDelete(int index, String text) {
+ int childCount = mEditTextList.getChildCount();
+ if (childCount == 1) {
+ return;
+ }
+
+ for (int i = index + 1; i < childCount; i++) {
+ ((NoteEditText) mEditTextList.getChildAt(i).findViewById(R.id.et_edit_text))
+ .setIndex(i - 1);
+ }
+
+ mEditTextList.removeViewAt(index);
+ NoteEditText edit = null;
+ if(index == 0) {
+ edit = (NoteEditText) mEditTextList.getChildAt(0).findViewById(
+ R.id.et_edit_text);
+ } else {
+ edit = (NoteEditText) mEditTextList.getChildAt(index - 1).findViewById(
+ R.id.et_edit_text);
+ }
+ int length = edit.length();
+ edit.append(text);
+ edit.requestFocus();
+ edit.setSelection(length);
+ }
+
+ public void onEditTextEnter(int index, String text) {
+ /**
+ * Should not happen, check for debug
+ */
+ if(index > mEditTextList.getChildCount()) {
+ Log.e(TAG, "Index out of mEditTextList boundrary, should not happen");
+ }
+
+ View view = getListItem(text, index);
+ mEditTextList.addView(view, index);
+ NoteEditText edit = (NoteEditText) view.findViewById(R.id.et_edit_text);
+ edit.requestFocus();
+ edit.setSelection(0);
+ for (int i = index + 1; i < mEditTextList.getChildCount(); i++) {
+ ((NoteEditText) mEditTextList.getChildAt(i).findViewById(R.id.et_edit_text))
+ .setIndex(i);
+ }
+ }
+
+ private void switchToListMode(String text) {
+ mEditTextList.removeAllViews();
+ String[] items = text.split("\n");
+ int index = 0;
+ for (String item : items) {
+ if(!TextUtils.isEmpty(item)) {
+ mEditTextList.addView(getListItem(item, index));
+ index++;
+ }
+ }
+ mEditTextList.addView(getListItem("", index));
+ mEditTextList.getChildAt(index).findViewById(R.id.et_edit_text).requestFocus();
+
+ mNoteEditor.setVisibility(View.GONE);
+ mEditTextList.setVisibility(View.VISIBLE);
+ }
+
+ private Spannable getHighlightQueryResult(String fullText, String userQuery) {
+ SpannableString spannable = new SpannableString(fullText == null ? "" : fullText);
+ if (!TextUtils.isEmpty(userQuery)) {
+ mPattern = Pattern.compile(userQuery);
+ Matcher m = mPattern.matcher(fullText);
+ int start = 0;
+ while (m.find(start)) {
+ spannable.setSpan(
+ new BackgroundColorSpan(this.getResources().getColor(
+ R.color.user_query_highlight)), m.start(), m.end(),
+ Spannable.SPAN_INCLUSIVE_EXCLUSIVE);
+ start = m.end();
+ }
+ }
+ return spannable;
+ }
+
+ private View getListItem(String item, int index) {
+ View view = LayoutInflater.from(this).inflate(R.layout.note_edit_list_item, null);
+ final NoteEditText edit = (NoteEditText) view.findViewById(R.id.et_edit_text);
+ edit.setTextAppearance(this, TextAppearanceResources.getTexAppearanceResource(mFontSizeId));
+ CheckBox cb = ((CheckBox) view.findViewById(R.id.cb_edit_item));
+ cb.setOnCheckedChangeListener(new OnCheckedChangeListener() {
+ public void onCheckedChanged(CompoundButton buttonView, boolean isChecked) {
+ if (isChecked) {
+ edit.setPaintFlags(edit.getPaintFlags() | Paint.STRIKE_THRU_TEXT_FLAG);
+ } else {
+ edit.setPaintFlags(Paint.ANTI_ALIAS_FLAG | Paint.DEV_KERN_TEXT_FLAG);
+ }
+ }
+ });
+
+ if (item.startsWith(TAG_CHECKED)) {
+ cb.setChecked(true);
+ edit.setPaintFlags(edit.getPaintFlags() | Paint.STRIKE_THRU_TEXT_FLAG);
+ item = item.substring(TAG_CHECKED.length(), item.length()).trim();
+ } else if (item.startsWith(TAG_UNCHECKED)) {
+ cb.setChecked(false);
+ edit.setPaintFlags(Paint.ANTI_ALIAS_FLAG | Paint.DEV_KERN_TEXT_FLAG);
+ item = item.substring(TAG_UNCHECKED.length(), item.length()).trim();
+ }
+
+ edit.setOnTextViewChangeListener(this);
+ edit.setIndex(index);
+ edit.setText(getHighlightQueryResult(item, mUserQuery));
+ return view;
+ }
+
+ public void onTextChange(int index, boolean hasText) {
+ if (index >= mEditTextList.getChildCount()) {
+ Log.e(TAG, "Wrong index, should not happen");
+ return;
+ }
+ if(hasText) {
+ mEditTextList.getChildAt(index).findViewById(R.id.cb_edit_item).setVisibility(View.VISIBLE);
+ } else {
+ mEditTextList.getChildAt(index).findViewById(R.id.cb_edit_item).setVisibility(View.GONE);
+ }
+ }
+
+ public void onCheckListModeChanged(int oldMode, int newMode) {
+ if (newMode == TextNote.MODE_CHECK_LIST) {
+ switchToListMode(mNoteEditor.getText().toString());
+ } else {
+ if (!getWorkingText()) {
+ mWorkingNote.setWorkingText(mWorkingNote.getContent().replace(TAG_UNCHECKED + " ",
+ ""));
+ }
+ mNoteEditor.setText(getHighlightQueryResult(mWorkingNote.getContent(), mUserQuery));
+ mEditTextList.setVisibility(View.GONE);
+ mNoteEditor.setVisibility(View.VISIBLE);
+ }
+ }
+
+ private boolean getWorkingText() {
+ boolean hasChecked = false;
+ if (mWorkingNote.getCheckListMode() == TextNote.MODE_CHECK_LIST) {
+ StringBuilder sb = new StringBuilder();
+ for (int i = 0; i < mEditTextList.getChildCount(); i++) {
+ View view = mEditTextList.getChildAt(i);
+ NoteEditText edit = (NoteEditText) view.findViewById(R.id.et_edit_text);
+ if (!TextUtils.isEmpty(edit.getText())) {
+ if (((CheckBox) view.findViewById(R.id.cb_edit_item)).isChecked()) {
+ sb.append(TAG_CHECKED).append(" ").append(edit.getText()).append("\n");
+ hasChecked = true;
+ } else {
+ sb.append(TAG_UNCHECKED).append(" ").append(edit.getText()).append("\n");
+ }
+ }
+ }
+ mWorkingNote.setWorkingText(sb.toString());
+ } else {
+ mWorkingNote.setWorkingText(mNoteEditor.getText().toString());
+ }
+ return hasChecked;
+ }
+
+ private boolean saveNote() {
+ getWorkingText();
+ boolean saved = mWorkingNote.saveNote();
+ if (saved) {
+ /**
+ * There are two modes from List view to edit view, open one note,
+ * create/edit a node. Opening node requires to the original
+ * position in the list when back from edit view, while creating a
+ * new node requires to the top of the list. This code
+ * {@link #RESULT_OK} is used to identify the create/edit state
+ */
+ setResult(RESULT_OK);
+ }
+ return saved;
+ }
+
+ private void sendToDesktop() {
+ /**
+ * Before send message to home, we should make sure that current
+ * editing note is exists in databases. So, for new note, firstly
+ * save it
+ */
+ if (!mWorkingNote.existInDatabase()) {
+ saveNote();
+ }
+
+ if (mWorkingNote.getNoteId() > 0) {
+ Intent sender = new Intent();
+ Intent shortcutIntent = new Intent(this, NoteEditActivity.class);
+ shortcutIntent.setAction(Intent.ACTION_VIEW);
+ shortcutIntent.putExtra(Intent.EXTRA_UID, mWorkingNote.getNoteId());
+ sender.putExtra(Intent.EXTRA_SHORTCUT_INTENT, shortcutIntent);
+ sender.putExtra(Intent.EXTRA_SHORTCUT_NAME,
+ makeShortcutIconTitle(mWorkingNote.getContent()));
+ sender.putExtra(Intent.EXTRA_SHORTCUT_ICON_RESOURCE,
+ Intent.ShortcutIconResource.fromContext(this, R.drawable.icon_app));
+ sender.putExtra("duplicate", true);
+ sender.setAction("com.android.launcher.action.INSTALL_SHORTCUT");
+ showToast(R.string.info_note_enter_desktop);
+ sendBroadcast(sender);
+ } else {
+ /**
+ * There is the condition that user has input nothing (the note is
+ * not worthy saving), we have no note id, remind the user that he
+ * should input something
+ */
+ Log.e(TAG, "Send to desktop error");
+ showToast(R.string.error_note_empty_for_send_to_desktop);
+ }
+ }
+
+ private String makeShortcutIconTitle(String content) {
+ content = content.replace(TAG_CHECKED, "");
+ content = content.replace(TAG_UNCHECKED, "");
+ return content.length() > SHORTCUT_ICON_TITLE_MAX_LEN ? content.substring(0,
+ SHORTCUT_ICON_TITLE_MAX_LEN) : content;
+ }
+
+ private void showToast(int resId) {
+ showToast(resId, Toast.LENGTH_SHORT);
+ }
+
+ private void showToast(int resId, int duration) {
+ Toast.makeText(this, resId, duration).show();
+ }
+}
diff --git a/src/src/Notes-master/src/net/micode/notes/ui/NoteEditText.java b/src/src/Notes-master/src/net/micode/notes/ui/NoteEditText.java
new file mode 100644
index 0000000..2afe2a8
--- /dev/null
+++ b/src/src/Notes-master/src/net/micode/notes/ui/NoteEditText.java
@@ -0,0 +1,217 @@
+/*
+ * Copyright (c) 2010-2011, The MiCode Open Source Community (www.micode.net)
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+
+package net.micode.notes.ui;
+
+import android.content.Context;
+import android.graphics.Rect;
+import android.text.Layout;
+import android.text.Selection;
+import android.text.Spanned;
+import android.text.TextUtils;
+import android.text.style.URLSpan;
+import android.util.AttributeSet;
+import android.util.Log;
+import android.view.ContextMenu;
+import android.view.KeyEvent;
+import android.view.MenuItem;
+import android.view.MenuItem.OnMenuItemClickListener;
+import android.view.MotionEvent;
+import android.widget.EditText;
+
+import net.micode.notes.R;
+
+import java.util.HashMap;
+import java.util.Map;
+
+public class NoteEditText extends EditText {
+ private static final String TAG = "NoteEditText";
+ private int mIndex;
+ private int mSelectionStartBeforeDelete;
+
+ private static final String SCHEME_TEL = "tel:" ;
+ private static final String SCHEME_HTTP = "http:" ;
+ private static final String SCHEME_EMAIL = "mailto:" ;
+
+ private static final Map sSchemaActionResMap = new HashMap();
+ static {
+ sSchemaActionResMap.put(SCHEME_TEL, R.string.note_link_tel);
+ sSchemaActionResMap.put(SCHEME_HTTP, R.string.note_link_web);
+ sSchemaActionResMap.put(SCHEME_EMAIL, R.string.note_link_email);
+ }
+
+ /**
+ * Call by the {@link NoteEditActivity} to delete or add edit text
+ */
+ public interface OnTextViewChangeListener {
+ /**
+ * Delete current edit text when {@link KeyEvent#KEYCODE_DEL} happens
+ * and the text is null
+ */
+ void onEditTextDelete(int index, String text);
+
+ /**
+ * Add edit text after current edit text when {@link KeyEvent#KEYCODE_ENTER}
+ * happen
+ */
+ void onEditTextEnter(int index, String text);
+
+ /**
+ * Hide or show item option when text change
+ */
+ void onTextChange(int index, boolean hasText);
+ }
+
+ private OnTextViewChangeListener mOnTextViewChangeListener;
+
+ public NoteEditText(Context context) {
+ super(context, null);
+ mIndex = 0;
+ }
+
+ public void setIndex(int index) {
+ mIndex = index;
+ }
+
+ public void setOnTextViewChangeListener(OnTextViewChangeListener listener) {
+ mOnTextViewChangeListener = listener;
+ }
+
+ public NoteEditText(Context context, AttributeSet attrs) {
+ super(context, attrs, android.R.attr.editTextStyle);
+ }
+
+ public NoteEditText(Context context, AttributeSet attrs, int defStyle) {
+ super(context, attrs, defStyle);
+ // TODO Auto-generated constructor stub
+ }
+
+ @Override
+ public boolean onTouchEvent(MotionEvent event) {
+ switch (event.getAction()) {
+ case MotionEvent.ACTION_DOWN:
+
+ int x = (int) event.getX();
+ int y = (int) event.getY();
+ x -= getTotalPaddingLeft();
+ y -= getTotalPaddingTop();
+ x += getScrollX();
+ y += getScrollY();
+
+ Layout layout = getLayout();
+ int line = layout.getLineForVertical(y);
+ int off = layout.getOffsetForHorizontal(line, x);
+ Selection.setSelection(getText(), off);
+ break;
+ }
+
+ return super.onTouchEvent(event);
+ }
+
+ @Override
+ public boolean onKeyDown(int keyCode, KeyEvent event) {
+ switch (keyCode) {
+ case KeyEvent.KEYCODE_ENTER:
+ if (mOnTextViewChangeListener != null) {
+ return false;
+ }
+ break;
+ case KeyEvent.KEYCODE_DEL:
+ mSelectionStartBeforeDelete = getSelectionStart();
+ break;
+ default:
+ break;
+ }
+ return super.onKeyDown(keyCode, event);
+ }
+
+ @Override
+ public boolean onKeyUp(int keyCode, KeyEvent event) {
+ switch(keyCode) {
+ case KeyEvent.KEYCODE_DEL:
+ if (mOnTextViewChangeListener != null) {
+ if (0 == mSelectionStartBeforeDelete && mIndex != 0) {
+ mOnTextViewChangeListener.onEditTextDelete(mIndex, getText().toString());
+ return true;
+ }
+ } else {
+ Log.d(TAG, "OnTextViewChangeListener was not seted");
+ }
+ break;
+ case KeyEvent.KEYCODE_ENTER:
+ if (mOnTextViewChangeListener != null) {
+ int selectionStart = getSelectionStart();
+ String text = getText().subSequence(selectionStart, length()).toString();
+ setText(getText().subSequence(0, selectionStart));
+ mOnTextViewChangeListener.onEditTextEnter(mIndex + 1, text);
+ } else {
+ Log.d(TAG, "OnTextViewChangeListener was not seted");
+ }
+ break;
+ default:
+ break;
+ }
+ return super.onKeyUp(keyCode, event);
+ }
+
+ @Override
+ protected void onFocusChanged(boolean focused, int direction, Rect previouslyFocusedRect) {
+ if (mOnTextViewChangeListener != null) {
+ if (!focused && TextUtils.isEmpty(getText())) {
+ mOnTextViewChangeListener.onTextChange(mIndex, false);
+ } else {
+ mOnTextViewChangeListener.onTextChange(mIndex, true);
+ }
+ }
+ super.onFocusChanged(focused, direction, previouslyFocusedRect);
+ }
+
+ @Override
+ protected void onCreateContextMenu(ContextMenu menu) {
+ if (getText() instanceof Spanned) {
+ int selStart = getSelectionStart();
+ int selEnd = getSelectionEnd();
+
+ int min = Math.min(selStart, selEnd);
+ int max = Math.max(selStart, selEnd);
+
+ final URLSpan[] urls = ((Spanned) getText()).getSpans(min, max, URLSpan.class);
+ if (urls.length == 1) {
+ int defaultResId = 0;
+ for(String schema: sSchemaActionResMap.keySet()) {
+ if(urls[0].getURL().indexOf(schema) >= 0) {
+ defaultResId = sSchemaActionResMap.get(schema);
+ break;
+ }
+ }
+
+ if (defaultResId == 0) {
+ defaultResId = R.string.note_link_other;
+ }
+
+ menu.add(0, 0, 0, defaultResId).setOnMenuItemClickListener(
+ new OnMenuItemClickListener() {
+ public boolean onMenuItemClick(MenuItem item) {
+ // goto a new intent
+ urls[0].onClick(NoteEditText.this);
+ return true;
+ }
+ });
+ }
+ }
+ super.onCreateContextMenu(menu);
+ }
+}
diff --git a/src/src/Notes-master/src/net/micode/notes/ui/NoteItemData.java b/src/src/Notes-master/src/net/micode/notes/ui/NoteItemData.java
new file mode 100644
index 0000000..0f5a878
--- /dev/null
+++ b/src/src/Notes-master/src/net/micode/notes/ui/NoteItemData.java
@@ -0,0 +1,224 @@
+/*
+ * Copyright (c) 2010-2011, The MiCode Open Source Community (www.micode.net)
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+
+package net.micode.notes.ui;
+
+import android.content.Context;
+import android.database.Cursor;
+import android.text.TextUtils;
+
+import net.micode.notes.data.Contact;
+import net.micode.notes.data.Notes;
+import net.micode.notes.data.Notes.NoteColumns;
+import net.micode.notes.tool.DataUtils;
+
+
+public class NoteItemData {
+ static final String [] PROJECTION = new String [] {
+ NoteColumns.ID,
+ NoteColumns.ALERTED_DATE,
+ NoteColumns.BG_COLOR_ID,
+ NoteColumns.CREATED_DATE,
+ NoteColumns.HAS_ATTACHMENT,
+ NoteColumns.MODIFIED_DATE,
+ NoteColumns.NOTES_COUNT,
+ NoteColumns.PARENT_ID,
+ NoteColumns.SNIPPET,
+ NoteColumns.TYPE,
+ NoteColumns.WIDGET_ID,
+ NoteColumns.WIDGET_TYPE,
+ };
+
+ private static final int ID_COLUMN = 0;
+ private static final int ALERTED_DATE_COLUMN = 1;
+ private static final int BG_COLOR_ID_COLUMN = 2;
+ private static final int CREATED_DATE_COLUMN = 3;
+ private static final int HAS_ATTACHMENT_COLUMN = 4;
+ private static final int MODIFIED_DATE_COLUMN = 5;
+ private static final int NOTES_COUNT_COLUMN = 6;
+ private static final int PARENT_ID_COLUMN = 7;
+ private static final int SNIPPET_COLUMN = 8;
+ private static final int TYPE_COLUMN = 9;
+ private static final int WIDGET_ID_COLUMN = 10;
+ private static final int WIDGET_TYPE_COLUMN = 11;
+
+ private long mId;
+ private long mAlertDate;
+ private int mBgColorId;
+ private long mCreatedDate;
+ private boolean mHasAttachment;
+ private long mModifiedDate;
+ private int mNotesCount;
+ private long mParentId;
+ private String mSnippet;
+ private int mType;
+ private int mWidgetId;
+ private int mWidgetType;
+ private String mName;
+ private String mPhoneNumber;
+
+ private boolean mIsLastItem;
+ private boolean mIsFirstItem;
+ private boolean mIsOnlyOneItem;
+ private boolean mIsOneNoteFollowingFolder;
+ private boolean mIsMultiNotesFollowingFolder;
+
+ public NoteItemData(Context context, Cursor cursor) {
+ mId = cursor.getLong(ID_COLUMN);
+ mAlertDate = cursor.getLong(ALERTED_DATE_COLUMN);
+ mBgColorId = cursor.getInt(BG_COLOR_ID_COLUMN);
+ mCreatedDate = cursor.getLong(CREATED_DATE_COLUMN);
+ mHasAttachment = (cursor.getInt(HAS_ATTACHMENT_COLUMN) > 0) ? true : false;
+ mModifiedDate = cursor.getLong(MODIFIED_DATE_COLUMN);
+ mNotesCount = cursor.getInt(NOTES_COUNT_COLUMN);
+ mParentId = cursor.getLong(PARENT_ID_COLUMN);
+ mSnippet = cursor.getString(SNIPPET_COLUMN);
+ mSnippet = mSnippet.replace(NoteEditActivity.TAG_CHECKED, "").replace(
+ NoteEditActivity.TAG_UNCHECKED, "");
+ mType = cursor.getInt(TYPE_COLUMN);
+ mWidgetId = cursor.getInt(WIDGET_ID_COLUMN);
+ mWidgetType = cursor.getInt(WIDGET_TYPE_COLUMN);
+
+ mPhoneNumber = "";
+ if (mParentId == Notes.ID_CALL_RECORD_FOLDER) {
+ mPhoneNumber = DataUtils.getCallNumberByNoteId(context.getContentResolver(), mId);
+ if (!TextUtils.isEmpty(mPhoneNumber)) {
+ mName = Contact.getContact(context, mPhoneNumber);
+ if (mName == null) {
+ mName = mPhoneNumber;
+ }
+ }
+ }
+
+ if (mName == null) {
+ mName = "";
+ }
+ checkPostion(cursor);
+ }
+
+ private void checkPostion(Cursor cursor) {
+ mIsLastItem = cursor.isLast() ? true : false;
+ mIsFirstItem = cursor.isFirst() ? true : false;
+ mIsOnlyOneItem = (cursor.getCount() == 1);
+ mIsMultiNotesFollowingFolder = false;
+ mIsOneNoteFollowingFolder = false;
+
+ if (mType == Notes.TYPE_NOTE && !mIsFirstItem) {
+ int position = cursor.getPosition();
+ if (cursor.moveToPrevious()) {
+ if (cursor.getInt(TYPE_COLUMN) == Notes.TYPE_FOLDER
+ || cursor.getInt(TYPE_COLUMN) == Notes.TYPE_SYSTEM) {
+ if (cursor.getCount() > (position + 1)) {
+ mIsMultiNotesFollowingFolder = true;
+ } else {
+ mIsOneNoteFollowingFolder = true;
+ }
+ }
+ if (!cursor.moveToNext()) {
+ throw new IllegalStateException("cursor move to previous but can't move back");
+ }
+ }
+ }
+ }
+
+ public boolean isOneFollowingFolder() {
+ return mIsOneNoteFollowingFolder;
+ }
+
+ public boolean isMultiFollowingFolder() {
+ return mIsMultiNotesFollowingFolder;
+ }
+
+ public boolean isLast() {
+ return mIsLastItem;
+ }
+
+ public String getCallName() {
+ return mName;
+ }
+
+ public boolean isFirst() {
+ return mIsFirstItem;
+ }
+
+ public boolean isSingle() {
+ return mIsOnlyOneItem;
+ }
+
+ public long getId() {
+ return mId;
+ }
+
+ public long getAlertDate() {
+ return mAlertDate;
+ }
+
+ public long getCreatedDate() {
+ return mCreatedDate;
+ }
+
+ public boolean hasAttachment() {
+ return mHasAttachment;
+ }
+
+ public long getModifiedDate() {
+ return mModifiedDate;
+ }
+
+ public int getBgColorId() {
+ return mBgColorId;
+ }
+
+ public long getParentId() {
+ return mParentId;
+ }
+
+ public int getNotesCount() {
+ return mNotesCount;
+ }
+
+ public long getFolderId () {
+ return mParentId;
+ }
+
+ public int getType() {
+ return mType;
+ }
+
+ public int getWidgetType() {
+ return mWidgetType;
+ }
+
+ public int getWidgetId() {
+ return mWidgetId;
+ }
+
+ public String getSnippet() {
+ return mSnippet;
+ }
+
+ public boolean hasAlert() {
+ return (mAlertDate > 0);
+ }
+
+ public boolean isCallRecord() {
+ return (mParentId == Notes.ID_CALL_RECORD_FOLDER && !TextUtils.isEmpty(mPhoneNumber));
+ }
+
+ public static int getNoteType(Cursor cursor) {
+ return cursor.getInt(TYPE_COLUMN);
+ }
+}
diff --git a/src/src/Notes-master/src/net/micode/notes/ui/NotesListActivity.java b/src/src/Notes-master/src/net/micode/notes/ui/NotesListActivity.java
new file mode 100644
index 0000000..e843aec
--- /dev/null
+++ b/src/src/Notes-master/src/net/micode/notes/ui/NotesListActivity.java
@@ -0,0 +1,954 @@
+/*
+ * Copyright (c) 2010-2011, The MiCode Open Source Community (www.micode.net)
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+
+package net.micode.notes.ui;
+
+import android.app.Activity;
+import android.app.AlertDialog;
+import android.app.Dialog;
+import android.appwidget.AppWidgetManager;
+import android.content.AsyncQueryHandler;
+import android.content.ContentResolver;
+import android.content.ContentValues;
+import android.content.Context;
+import android.content.DialogInterface;
+import android.content.Intent;
+import android.content.SharedPreferences;
+import android.database.Cursor;
+import android.os.AsyncTask;
+import android.os.Bundle;
+import android.preference.PreferenceManager;
+import android.text.Editable;
+import android.text.TextUtils;
+import android.text.TextWatcher;
+import android.util.Log;
+import android.view.ActionMode;
+import android.view.ContextMenu;
+import android.view.ContextMenu.ContextMenuInfo;
+import android.view.Display;
+import android.view.HapticFeedbackConstants;
+import android.view.LayoutInflater;
+import android.view.Menu;
+import android.view.MenuItem;
+import android.view.MenuItem.OnMenuItemClickListener;
+import android.view.MotionEvent;
+import android.view.View;
+import android.view.View.OnClickListener;
+import android.view.View.OnCreateContextMenuListener;
+import android.view.View.OnTouchListener;
+import android.view.inputmethod.InputMethodManager;
+import android.widget.AdapterView;
+import android.widget.AdapterView.OnItemClickListener;
+import android.widget.AdapterView.OnItemLongClickListener;
+import android.widget.Button;
+import android.widget.EditText;
+import android.widget.ListView;
+import android.widget.PopupMenu;
+import android.widget.TextView;
+import android.widget.Toast;
+
+import net.micode.notes.R;
+import net.micode.notes.data.Notes;
+import net.micode.notes.data.Notes.NoteColumns;
+import net.micode.notes.gtask.remote.GTaskSyncService;
+import net.micode.notes.model.WorkingNote;
+import net.micode.notes.tool.BackupUtils;
+import net.micode.notes.tool.DataUtils;
+import net.micode.notes.tool.ResourceParser;
+import net.micode.notes.ui.NotesListAdapter.AppWidgetAttribute;
+import net.micode.notes.widget.NoteWidgetProvider_2x;
+import net.micode.notes.widget.NoteWidgetProvider_4x;
+
+import java.io.BufferedReader;
+import java.io.IOException;
+import java.io.InputStream;
+import java.io.InputStreamReader;
+import java.util.HashSet;
+
+public class NotesListActivity extends Activity implements OnClickListener, OnItemLongClickListener {
+ private static final int FOLDER_NOTE_LIST_QUERY_TOKEN = 0;
+
+ private static final int FOLDER_LIST_QUERY_TOKEN = 1;
+
+ private static final int MENU_FOLDER_DELETE = 0;
+
+ private static final int MENU_FOLDER_VIEW = 1;
+
+ private static final int MENU_FOLDER_CHANGE_NAME = 2;
+
+ private static final String PREFERENCE_ADD_INTRODUCTION = "net.micode.notes.introduction";
+
+ private enum ListEditState {
+ NOTE_LIST, SUB_FOLDER, CALL_RECORD_FOLDER
+ };
+
+ private ListEditState mState;
+
+ private BackgroundQueryHandler mBackgroundQueryHandler;
+
+ private NotesListAdapter mNotesListAdapter;
+
+ private ListView mNotesListView;
+
+ private Button mAddNewNote;
+
+ private boolean mDispatch;
+
+ private int mOriginY;
+
+ private int mDispatchY;
+
+ private TextView mTitleBar;
+
+ private long mCurrentFolderId;
+
+ private ContentResolver mContentResolver;
+
+ private ModeCallback mModeCallBack;
+
+ private static final String TAG = "NotesListActivity";
+
+ public static final int NOTES_LISTVIEW_SCROLL_RATE = 30;
+
+ private NoteItemData mFocusNoteDataItem;
+
+ private static final String NORMAL_SELECTION = NoteColumns.PARENT_ID + "=?";
+
+ private static final String ROOT_FOLDER_SELECTION = "(" + NoteColumns.TYPE + "<>"
+ + Notes.TYPE_SYSTEM + " AND " + NoteColumns.PARENT_ID + "=?)" + " OR ("
+ + NoteColumns.ID + "=" + Notes.ID_CALL_RECORD_FOLDER + " AND "
+ + NoteColumns.NOTES_COUNT + ">0)";
+
+ private final static int REQUEST_CODE_OPEN_NODE = 102;
+ private final static int REQUEST_CODE_NEW_NODE = 103;
+
+ @Override
+ protected void onCreate(Bundle savedInstanceState) {
+ super.onCreate(savedInstanceState);
+ setContentView(R.layout.note_list);
+ initResources();
+
+ /**
+ * Insert an introduction when user firstly use this application
+ */
+ setAppInfoFromRawRes();
+ }
+
+ @Override
+ protected void onActivityResult(int requestCode, int resultCode, Intent data) {
+ if (resultCode == RESULT_OK
+ && (requestCode == REQUEST_CODE_OPEN_NODE || requestCode == REQUEST_CODE_NEW_NODE)) {
+ mNotesListAdapter.changeCursor(null);
+ } else {
+ super.onActivityResult(requestCode, resultCode, data);
+ }
+ }
+
+ private void setAppInfoFromRawRes() {
+ SharedPreferences sp = PreferenceManager.getDefaultSharedPreferences(this);
+ if (!sp.getBoolean(PREFERENCE_ADD_INTRODUCTION, false)) {
+ StringBuilder sb = new StringBuilder();
+ InputStream in = null;
+ try {
+ in = getResources().openRawResource(R.raw.introduction);
+ if (in != null) {
+ InputStreamReader isr = new InputStreamReader(in);
+ BufferedReader br = new BufferedReader(isr);
+ char [] buf = new char[1024];
+ int len = 0;
+ while ((len = br.read(buf)) > 0) {
+ sb.append(buf, 0, len);
+ }
+ } else {
+ Log.e(TAG, "Read introduction file error");
+ return;
+ }
+ } catch (IOException e) {
+ e.printStackTrace();
+ return;
+ } finally {
+ if(in != null) {
+ try {
+ in.close();
+ } catch (IOException e) {
+ // TODO Auto-generated catch block
+ e.printStackTrace();
+ }
+ }
+ }
+
+ WorkingNote note = WorkingNote.createEmptyNote(this, Notes.ID_ROOT_FOLDER,
+ AppWidgetManager.INVALID_APPWIDGET_ID, Notes.TYPE_WIDGET_INVALIDE,
+ ResourceParser.RED);
+ note.setWorkingText(sb.toString());
+ if (note.saveNote()) {
+ sp.edit().putBoolean(PREFERENCE_ADD_INTRODUCTION, true).commit();
+ } else {
+ Log.e(TAG, "Save introduction note error");
+ return;
+ }
+ }
+ }
+
+ @Override
+ protected void onStart() {
+ super.onStart();
+ startAsyncNotesListQuery();
+ }
+
+ private void initResources() {
+ mContentResolver = this.getContentResolver();
+ mBackgroundQueryHandler = new BackgroundQueryHandler(this.getContentResolver());
+ mCurrentFolderId = Notes.ID_ROOT_FOLDER;
+ mNotesListView = (ListView) findViewById(R.id.notes_list);
+ mNotesListView.addFooterView(LayoutInflater.from(this).inflate(R.layout.note_list_footer, null),
+ null, false);
+ mNotesListView.setOnItemClickListener(new OnListItemClickListener());
+ mNotesListView.setOnItemLongClickListener(this);
+ mNotesListAdapter = new NotesListAdapter(this);
+ mNotesListView.setAdapter(mNotesListAdapter);
+ mAddNewNote = (Button) findViewById(R.id.btn_new_note);
+ mAddNewNote.setOnClickListener(this);
+ mAddNewNote.setOnTouchListener(new NewNoteOnTouchListener());
+ mDispatch = false;
+ mDispatchY = 0;
+ mOriginY = 0;
+ mTitleBar = (TextView) findViewById(R.id.tv_title_bar);
+ mState = ListEditState.NOTE_LIST;
+ mModeCallBack = new ModeCallback();
+ }
+
+ private class ModeCallback implements ListView.MultiChoiceModeListener, OnMenuItemClickListener {
+ private DropdownMenu mDropDownMenu;
+ private ActionMode mActionMode;
+ private MenuItem mMoveMenu;
+
+ public boolean onCreateActionMode(ActionMode mode, Menu menu) {
+ getMenuInflater().inflate(R.menu.note_list_options, menu);
+ menu.findItem(R.id.delete).setOnMenuItemClickListener(this);
+ mMoveMenu = menu.findItem(R.id.move);
+ if (mFocusNoteDataItem.getParentId() == Notes.ID_CALL_RECORD_FOLDER
+ || DataUtils.getUserFolderCount(mContentResolver) == 0) {
+ mMoveMenu.setVisible(false);
+ } else {
+ mMoveMenu.setVisible(true);
+ mMoveMenu.setOnMenuItemClickListener(this);
+ }
+ mActionMode = mode;
+ mNotesListAdapter.setChoiceMode(true);
+ mNotesListView.setLongClickable(false);
+ mAddNewNote.setVisibility(View.GONE);
+
+ View customView = LayoutInflater.from(NotesListActivity.this).inflate(
+ R.layout.note_list_dropdown_menu, null);
+ mode.setCustomView(customView);
+ mDropDownMenu = new DropdownMenu(NotesListActivity.this,
+ (Button) customView.findViewById(R.id.selection_menu),
+ R.menu.note_list_dropdown);
+ mDropDownMenu.setOnDropdownMenuItemClickListener(new PopupMenu.OnMenuItemClickListener(){
+ public boolean onMenuItemClick(MenuItem item) {
+ mNotesListAdapter.selectAll(!mNotesListAdapter.isAllSelected());
+ updateMenu();
+ return true;
+ }
+
+ });
+ return true;
+ }
+
+ private void updateMenu() {
+ int selectedCount = mNotesListAdapter.getSelectedCount();
+ // Update dropdown menu
+ String format = getResources().getString(R.string.menu_select_title, selectedCount);
+ mDropDownMenu.setTitle(format);
+ MenuItem item = mDropDownMenu.findItem(R.id.action_select_all);
+ if (item != null) {
+ if (mNotesListAdapter.isAllSelected()) {
+ item.setChecked(true);
+ item.setTitle(R.string.menu_deselect_all);
+ } else {
+ item.setChecked(false);
+ item.setTitle(R.string.menu_select_all);
+ }
+ }
+ }
+
+ public boolean onPrepareActionMode(ActionMode mode, Menu menu) {
+ // TODO Auto-generated method stub
+ return false;
+ }
+
+ public boolean onActionItemClicked(ActionMode mode, MenuItem item) {
+ // TODO Auto-generated method stub
+ return false;
+ }
+
+ public void onDestroyActionMode(ActionMode mode) {
+ mNotesListAdapter.setChoiceMode(false);
+ mNotesListView.setLongClickable(true);
+ mAddNewNote.setVisibility(View.VISIBLE);
+ }
+
+ public void finishActionMode() {
+ mActionMode.finish();
+ }
+
+ public void onItemCheckedStateChanged(ActionMode mode, int position, long id,
+ boolean checked) {
+ mNotesListAdapter.setCheckedItem(position, checked);
+ updateMenu();
+ }
+
+ public boolean onMenuItemClick(MenuItem item) {
+ if (mNotesListAdapter.getSelectedCount() == 0) {
+ Toast.makeText(NotesListActivity.this, getString(R.string.menu_select_none),
+ Toast.LENGTH_SHORT).show();
+ return true;
+ }
+
+ switch (item.getItemId()) {
+ case R.id.delete:
+ AlertDialog.Builder builder = new AlertDialog.Builder(NotesListActivity.this);
+ builder.setTitle(getString(R.string.alert_title_delete));
+ builder.setIcon(android.R.drawable.ic_dialog_alert);
+ builder.setMessage(getString(R.string.alert_message_delete_notes,
+ mNotesListAdapter.getSelectedCount()));
+ builder.setPositiveButton(android.R.string.ok,
+ new DialogInterface.OnClickListener() {
+ public void onClick(DialogInterface dialog,
+ int which) {
+ batchDelete();
+ }
+ });
+ builder.setNegativeButton(android.R.string.cancel, null);
+ builder.show();
+ break;
+ case R.id.move:
+ startQueryDestinationFolders();
+ break;
+ default:
+ return false;
+ }
+ return true;
+ }
+ }
+
+ private class NewNoteOnTouchListener implements OnTouchListener {
+
+ public boolean onTouch(View v, MotionEvent event) {
+ switch (event.getAction()) {
+ case MotionEvent.ACTION_DOWN: {
+ Display display = getWindowManager().getDefaultDisplay();
+ int screenHeight = display.getHeight();
+ int newNoteViewHeight = mAddNewNote.getHeight();
+ int start = screenHeight - newNoteViewHeight;
+ int eventY = start + (int) event.getY();
+ /**
+ * Minus TitleBar's height
+ */
+ if (mState == ListEditState.SUB_FOLDER) {
+ eventY -= mTitleBar.getHeight();
+ start -= mTitleBar.getHeight();
+ }
+ /**
+ * HACKME:When click the transparent part of "New Note" button, dispatch
+ * the event to the list view behind this button. The transparent part of
+ * "New Note" button could be expressed by formula y=-0.12x+94(Unit:pixel)
+ * and the line top of the button. The coordinate based on left of the "New
+ * Note" button. The 94 represents maximum height of the transparent part.
+ * Notice that, if the background of the button changes, the formula should
+ * also change. This is very bad, just for the UI designer's strong requirement.
+ */
+ if (event.getY() < (event.getX() * (-0.12) + 94)) {
+ View view = mNotesListView.getChildAt(mNotesListView.getChildCount() - 1
+ - mNotesListView.getFooterViewsCount());
+ if (view != null && view.getBottom() > start
+ && (view.getTop() < (start + 94))) {
+ mOriginY = (int) event.getY();
+ mDispatchY = eventY;
+ event.setLocation(event.getX(), mDispatchY);
+ mDispatch = true;
+ return mNotesListView.dispatchTouchEvent(event);
+ }
+ }
+ break;
+ }
+ case MotionEvent.ACTION_MOVE: {
+ if (mDispatch) {
+ mDispatchY += (int) event.getY() - mOriginY;
+ event.setLocation(event.getX(), mDispatchY);
+ return mNotesListView.dispatchTouchEvent(event);
+ }
+ break;
+ }
+ default: {
+ if (mDispatch) {
+ event.setLocation(event.getX(), mDispatchY);
+ mDispatch = false;
+ return mNotesListView.dispatchTouchEvent(event);
+ }
+ break;
+ }
+ }
+ return false;
+ }
+
+ };
+
+ private void startAsyncNotesListQuery() {
+ String selection = (mCurrentFolderId == Notes.ID_ROOT_FOLDER) ? ROOT_FOLDER_SELECTION
+ : NORMAL_SELECTION;
+ mBackgroundQueryHandler.startQuery(FOLDER_NOTE_LIST_QUERY_TOKEN, null,
+ Notes.CONTENT_NOTE_URI, NoteItemData.PROJECTION, selection, new String[] {
+ String.valueOf(mCurrentFolderId)
+ }, NoteColumns.TYPE + " DESC," + NoteColumns.MODIFIED_DATE + " DESC");
+ }
+
+ private final class BackgroundQueryHandler extends AsyncQueryHandler {
+ public BackgroundQueryHandler(ContentResolver contentResolver) {
+ super(contentResolver);
+ }
+
+ @Override
+ protected void onQueryComplete(int token, Object cookie, Cursor cursor) {
+ switch (token) {
+ case FOLDER_NOTE_LIST_QUERY_TOKEN:
+ mNotesListAdapter.changeCursor(cursor);
+ break;
+ case FOLDER_LIST_QUERY_TOKEN:
+ if (cursor != null && cursor.getCount() > 0) {
+ showFolderListMenu(cursor);
+ } else {
+ Log.e(TAG, "Query folder failed");
+ }
+ break;
+ default:
+ return;
+ }
+ }
+ }
+
+ private void showFolderListMenu(Cursor cursor) {
+ AlertDialog.Builder builder = new AlertDialog.Builder(NotesListActivity.this);
+ builder.setTitle(R.string.menu_title_select_folder);
+ final FoldersListAdapter adapter = new FoldersListAdapter(this, cursor);
+ builder.setAdapter(adapter, new DialogInterface.OnClickListener() {
+
+ public void onClick(DialogInterface dialog, int which) {
+ DataUtils.batchMoveToFolder(mContentResolver,
+ mNotesListAdapter.getSelectedItemIds(), adapter.getItemId(which));
+ Toast.makeText(
+ NotesListActivity.this,
+ getString(R.string.format_move_notes_to_folder,
+ mNotesListAdapter.getSelectedCount(),
+ adapter.getFolderName(NotesListActivity.this, which)),
+ Toast.LENGTH_SHORT).show();
+ mModeCallBack.finishActionMode();
+ }
+ });
+ builder.show();
+ }
+
+ private void createNewNote() {
+ Intent intent = new Intent(this, NoteEditActivity.class);
+ intent.setAction(Intent.ACTION_INSERT_OR_EDIT);
+ intent.putExtra(Notes.INTENT_EXTRA_FOLDER_ID, mCurrentFolderId);
+ this.startActivityForResult(intent, REQUEST_CODE_NEW_NODE);
+ }
+
+ private void batchDelete() {
+ new AsyncTask>() {
+ protected HashSet doInBackground(Void... unused) {
+ HashSet widgets = mNotesListAdapter.getSelectedWidget();
+ if (!isSyncMode()) {
+ // if not synced, delete notes directly
+ if (DataUtils.batchDeleteNotes(mContentResolver, mNotesListAdapter
+ .getSelectedItemIds())) {
+ } else {
+ Log.e(TAG, "Delete notes error, should not happens");
+ }
+ } else {
+ // in sync mode, we'll move the deleted note into the trash
+ // folder
+ if (!DataUtils.batchMoveToFolder(mContentResolver, mNotesListAdapter
+ .getSelectedItemIds(), Notes.ID_TRASH_FOLER)) {
+ Log.e(TAG, "Move notes to trash folder error, should not happens");
+ }
+ }
+ return widgets;
+ }
+
+ @Override
+ protected void onPostExecute(HashSet widgets) {
+ if (widgets != null) {
+ for (AppWidgetAttribute widget : widgets) {
+ if (widget.widgetId != AppWidgetManager.INVALID_APPWIDGET_ID
+ && widget.widgetType != Notes.TYPE_WIDGET_INVALIDE) {
+ updateWidget(widget.widgetId, widget.widgetType);
+ }
+ }
+ }
+ mModeCallBack.finishActionMode();
+ }
+ }.execute();
+ }
+
+ private void deleteFolder(long folderId) {
+ if (folderId == Notes.ID_ROOT_FOLDER) {
+ Log.e(TAG, "Wrong folder id, should not happen " + folderId);
+ return;
+ }
+
+ HashSet ids = new HashSet();
+ ids.add(folderId);
+ HashSet widgets = DataUtils.getFolderNoteWidget(mContentResolver,
+ folderId);
+ if (!isSyncMode()) {
+ // if not synced, delete folder directly
+ DataUtils.batchDeleteNotes(mContentResolver, ids);
+ } else {
+ // in sync mode, we'll move the deleted folder into the trash folder
+ DataUtils.batchMoveToFolder(mContentResolver, ids, Notes.ID_TRASH_FOLER);
+ }
+ if (widgets != null) {
+ for (AppWidgetAttribute widget : widgets) {
+ if (widget.widgetId != AppWidgetManager.INVALID_APPWIDGET_ID
+ && widget.widgetType != Notes.TYPE_WIDGET_INVALIDE) {
+ updateWidget(widget.widgetId, widget.widgetType);
+ }
+ }
+ }
+ }
+
+ private void openNode(NoteItemData data) {
+ Intent intent = new Intent(this, NoteEditActivity.class);
+ intent.setAction(Intent.ACTION_VIEW);
+ intent.putExtra(Intent.EXTRA_UID, data.getId());
+ this.startActivityForResult(intent, REQUEST_CODE_OPEN_NODE);
+ }
+
+ private void openFolder(NoteItemData data) {
+ mCurrentFolderId = data.getId();
+ startAsyncNotesListQuery();
+ if (data.getId() == Notes.ID_CALL_RECORD_FOLDER) {
+ mState = ListEditState.CALL_RECORD_FOLDER;
+ mAddNewNote.setVisibility(View.GONE);
+ } else {
+ mState = ListEditState.SUB_FOLDER;
+ }
+ if (data.getId() == Notes.ID_CALL_RECORD_FOLDER) {
+ mTitleBar.setText(R.string.call_record_folder_name);
+ } else {
+ mTitleBar.setText(data.getSnippet());
+ }
+ mTitleBar.setVisibility(View.VISIBLE);
+ }
+
+ public void onClick(View v) {
+ switch (v.getId()) {
+ case R.id.btn_new_note:
+ createNewNote();
+ break;
+ default:
+ break;
+ }
+ }
+
+ private void showSoftInput() {
+ InputMethodManager inputMethodManager = (InputMethodManager) getSystemService(Context.INPUT_METHOD_SERVICE);
+ if (inputMethodManager != null) {
+ inputMethodManager.toggleSoftInput(InputMethodManager.SHOW_FORCED, 0);
+ }
+ }
+
+ private void hideSoftInput(View view) {
+ InputMethodManager inputMethodManager = (InputMethodManager) getSystemService(Context.INPUT_METHOD_SERVICE);
+ inputMethodManager.hideSoftInputFromWindow(view.getWindowToken(), 0);
+ }
+
+ private void showCreateOrModifyFolderDialog(final boolean create) {
+ final AlertDialog.Builder builder = new AlertDialog.Builder(this);
+ View view = LayoutInflater.from(this).inflate(R.layout.dialog_edit_text, null);
+ final EditText etName = (EditText) view.findViewById(R.id.et_foler_name);
+ showSoftInput();
+ if (!create) {
+ if (mFocusNoteDataItem != null) {
+ etName.setText(mFocusNoteDataItem.getSnippet());
+ builder.setTitle(getString(R.string.menu_folder_change_name));
+ } else {
+ Log.e(TAG, "The long click data item is null");
+ return;
+ }
+ } else {
+ etName.setText("");
+ builder.setTitle(this.getString(R.string.menu_create_folder));
+ }
+
+ builder.setPositiveButton(android.R.string.ok, null);
+ builder.setNegativeButton(android.R.string.cancel, new DialogInterface.OnClickListener() {
+ public void onClick(DialogInterface dialog, int which) {
+ hideSoftInput(etName);
+ }
+ });
+
+ final Dialog dialog = builder.setView(view).show();
+ final Button positive = (Button)dialog.findViewById(android.R.id.button1);
+ positive.setOnClickListener(new OnClickListener() {
+ public void onClick(View v) {
+ hideSoftInput(etName);
+ String name = etName.getText().toString();
+ if (DataUtils.checkVisibleFolderName(mContentResolver, name)) {
+ Toast.makeText(NotesListActivity.this, getString(R.string.folder_exist, name),
+ Toast.LENGTH_LONG).show();
+ etName.setSelection(0, etName.length());
+ return;
+ }
+ if (!create) {
+ if (!TextUtils.isEmpty(name)) {
+ ContentValues values = new ContentValues();
+ values.put(NoteColumns.SNIPPET, name);
+ values.put(NoteColumns.TYPE, Notes.TYPE_FOLDER);
+ values.put(NoteColumns.LOCAL_MODIFIED, 1);
+ mContentResolver.update(Notes.CONTENT_NOTE_URI, values, NoteColumns.ID
+ + "=?", new String[] {
+ String.valueOf(mFocusNoteDataItem.getId())
+ });
+ }
+ } else if (!TextUtils.isEmpty(name)) {
+ ContentValues values = new ContentValues();
+ values.put(NoteColumns.SNIPPET, name);
+ values.put(NoteColumns.TYPE, Notes.TYPE_FOLDER);
+ mContentResolver.insert(Notes.CONTENT_NOTE_URI, values);
+ }
+ dialog.dismiss();
+ }
+ });
+
+ if (TextUtils.isEmpty(etName.getText())) {
+ positive.setEnabled(false);
+ }
+ /**
+ * When the name edit text is null, disable the positive button
+ */
+ etName.addTextChangedListener(new TextWatcher() {
+ public void beforeTextChanged(CharSequence s, int start, int count, int after) {
+ // TODO Auto-generated method stub
+
+ }
+
+ public void onTextChanged(CharSequence s, int start, int before, int count) {
+ if (TextUtils.isEmpty(etName.getText())) {
+ positive.setEnabled(false);
+ } else {
+ positive.setEnabled(true);
+ }
+ }
+
+ public void afterTextChanged(Editable s) {
+ // TODO Auto-generated method stub
+
+ }
+ });
+ }
+
+ @Override
+ public void onBackPressed() {
+ switch (mState) {
+ case SUB_FOLDER:
+ mCurrentFolderId = Notes.ID_ROOT_FOLDER;
+ mState = ListEditState.NOTE_LIST;
+ startAsyncNotesListQuery();
+ mTitleBar.setVisibility(View.GONE);
+ break;
+ case CALL_RECORD_FOLDER:
+ mCurrentFolderId = Notes.ID_ROOT_FOLDER;
+ mState = ListEditState.NOTE_LIST;
+ mAddNewNote.setVisibility(View.VISIBLE);
+ mTitleBar.setVisibility(View.GONE);
+ startAsyncNotesListQuery();
+ break;
+ case NOTE_LIST:
+ super.onBackPressed();
+ break;
+ default:
+ break;
+ }
+ }
+
+ private void updateWidget(int appWidgetId, int appWidgetType) {
+ Intent intent = new Intent(AppWidgetManager.ACTION_APPWIDGET_UPDATE);
+ if (appWidgetType == Notes.TYPE_WIDGET_2X) {
+ intent.setClass(this, NoteWidgetProvider_2x.class);
+ } else if (appWidgetType == Notes.TYPE_WIDGET_4X) {
+ intent.setClass(this, NoteWidgetProvider_4x.class);
+ } else {
+ Log.e(TAG, "Unspported widget type");
+ return;
+ }
+
+ intent.putExtra(AppWidgetManager.EXTRA_APPWIDGET_IDS, new int[] {
+ appWidgetId
+ });
+
+ sendBroadcast(intent);
+ setResult(RESULT_OK, intent);
+ }
+
+ private final OnCreateContextMenuListener mFolderOnCreateContextMenuListener = new OnCreateContextMenuListener() {
+ public void onCreateContextMenu(ContextMenu menu, View v, ContextMenuInfo menuInfo) {
+ if (mFocusNoteDataItem != null) {
+ menu.setHeaderTitle(mFocusNoteDataItem.getSnippet());
+ menu.add(0, MENU_FOLDER_VIEW, 0, R.string.menu_folder_view);
+ menu.add(0, MENU_FOLDER_DELETE, 0, R.string.menu_folder_delete);
+ menu.add(0, MENU_FOLDER_CHANGE_NAME, 0, R.string.menu_folder_change_name);
+ }
+ }
+ };
+
+ @Override
+ public void onContextMenuClosed(Menu menu) {
+ if (mNotesListView != null) {
+ mNotesListView.setOnCreateContextMenuListener(null);
+ }
+ super.onContextMenuClosed(menu);
+ }
+
+ @Override
+ public boolean onContextItemSelected(MenuItem item) {
+ if (mFocusNoteDataItem == null) {
+ Log.e(TAG, "The long click data item is null");
+ return false;
+ }
+ switch (item.getItemId()) {
+ case MENU_FOLDER_VIEW:
+ openFolder(mFocusNoteDataItem);
+ break;
+ case MENU_FOLDER_DELETE:
+ AlertDialog.Builder builder = new AlertDialog.Builder(this);
+ builder.setTitle(getString(R.string.alert_title_delete));
+ builder.setIcon(android.R.drawable.ic_dialog_alert);
+ builder.setMessage(getString(R.string.alert_message_delete_folder));
+ builder.setPositiveButton(android.R.string.ok,
+ new DialogInterface.OnClickListener() {
+ public void onClick(DialogInterface dialog, int which) {
+ deleteFolder(mFocusNoteDataItem.getId());
+ }
+ });
+ builder.setNegativeButton(android.R.string.cancel, null);
+ builder.show();
+ break;
+ case MENU_FOLDER_CHANGE_NAME:
+ showCreateOrModifyFolderDialog(false);
+ break;
+ default:
+ break;
+ }
+
+ return true;
+ }
+
+ @Override
+ public boolean onPrepareOptionsMenu(Menu menu) {
+ menu.clear();
+ if (mState == ListEditState.NOTE_LIST) {
+ getMenuInflater().inflate(R.menu.note_list, menu);
+ // set sync or sync_cancel
+ menu.findItem(R.id.menu_sync).setTitle(
+ GTaskSyncService.isSyncing() ? R.string.menu_sync_cancel : R.string.menu_sync);
+ } else if (mState == ListEditState.SUB_FOLDER) {
+ getMenuInflater().inflate(R.menu.sub_folder, menu);
+ } else if (mState == ListEditState.CALL_RECORD_FOLDER) {
+ getMenuInflater().inflate(R.menu.call_record_folder, menu);
+ } else {
+ Log.e(TAG, "Wrong state:" + mState);
+ }
+ return true;
+ }
+
+ @Override
+ public boolean onOptionsItemSelected(MenuItem item) {
+ switch (item.getItemId()) {
+ case R.id.menu_new_folder: {
+ showCreateOrModifyFolderDialog(true);
+ break;
+ }
+ case R.id.menu_export_text: {
+ exportNoteToText();
+ break;
+ }
+ case R.id.menu_sync: {
+ if (isSyncMode()) {
+ if (TextUtils.equals(item.getTitle(), getString(R.string.menu_sync))) {
+ GTaskSyncService.startSync(this);
+ } else {
+ GTaskSyncService.cancelSync(this);
+ }
+ } else {
+ startPreferenceActivity();
+ }
+ break;
+ }
+ case R.id.menu_setting: {
+ startPreferenceActivity();
+ break;
+ }
+ case R.id.menu_new_note: {
+ createNewNote();
+ break;
+ }
+ case R.id.menu_search:
+ onSearchRequested();
+ break;
+ default:
+ break;
+ }
+ return true;
+ }
+
+ @Override
+ public boolean onSearchRequested() {
+ startSearch(null, false, null /* appData */, false);
+ return true;
+ }
+
+ private void exportNoteToText() {
+ final BackupUtils backup = BackupUtils.getInstance(NotesListActivity.this);
+ new AsyncTask() {
+
+ @Override
+ protected Integer doInBackground(Void... unused) {
+ return backup.exportToText();
+ }
+
+ @Override
+ protected void onPostExecute(Integer result) {
+ if (result == BackupUtils.STATE_SD_CARD_UNMOUONTED) {
+ AlertDialog.Builder builder = new AlertDialog.Builder(NotesListActivity.this);
+ builder.setTitle(NotesListActivity.this
+ .getString(R.string.failed_sdcard_export));
+ builder.setMessage(NotesListActivity.this
+ .getString(R.string.error_sdcard_unmounted));
+ builder.setPositiveButton(android.R.string.ok, null);
+ builder.show();
+ } else if (result == BackupUtils.STATE_SUCCESS) {
+ AlertDialog.Builder builder = new AlertDialog.Builder(NotesListActivity.this);
+ builder.setTitle(NotesListActivity.this
+ .getString(R.string.success_sdcard_export));
+ builder.setMessage(NotesListActivity.this.getString(
+ R.string.format_exported_file_location, backup
+ .getExportedTextFileName(), backup.getExportedTextFileDir()));
+ builder.setPositiveButton(android.R.string.ok, null);
+ builder.show();
+ } else if (result == BackupUtils.STATE_SYSTEM_ERROR) {
+ AlertDialog.Builder builder = new AlertDialog.Builder(NotesListActivity.this);
+ builder.setTitle(NotesListActivity.this
+ .getString(R.string.failed_sdcard_export));
+ builder.setMessage(NotesListActivity.this
+ .getString(R.string.error_sdcard_export));
+ builder.setPositiveButton(android.R.string.ok, null);
+ builder.show();
+ }
+ }
+
+ }.execute();
+ }
+
+ private boolean isSyncMode() {
+ return NotesPreferenceActivity.getSyncAccountName(this).trim().length() > 0;
+ }
+
+ private void startPreferenceActivity() {
+ Activity from = getParent() != null ? getParent() : this;
+ Intent intent = new Intent(from, NotesPreferenceActivity.class);
+ from.startActivityIfNeeded(intent, -1);
+ }
+
+ private class OnListItemClickListener implements OnItemClickListener {
+
+ public void onItemClick(AdapterView> parent, View view, int position, long id) {
+ if (view instanceof NotesListItem) {
+ NoteItemData item = ((NotesListItem) view).getItemData();
+ if (mNotesListAdapter.isInChoiceMode()) {
+ if (item.getType() == Notes.TYPE_NOTE) {
+ position = position - mNotesListView.getHeaderViewsCount();
+ mModeCallBack.onItemCheckedStateChanged(null, position, id,
+ !mNotesListAdapter.isSelectedItem(position));
+ }
+ return;
+ }
+
+ switch (mState) {
+ case NOTE_LIST:
+ if (item.getType() == Notes.TYPE_FOLDER
+ || item.getType() == Notes.TYPE_SYSTEM) {
+ openFolder(item);
+ } else if (item.getType() == Notes.TYPE_NOTE) {
+ openNode(item);
+ } else {
+ Log.e(TAG, "Wrong note type in NOTE_LIST");
+ }
+ break;
+ case SUB_FOLDER:
+ case CALL_RECORD_FOLDER:
+ if (item.getType() == Notes.TYPE_NOTE) {
+ openNode(item);
+ } else {
+ Log.e(TAG, "Wrong note type in SUB_FOLDER");
+ }
+ break;
+ default:
+ break;
+ }
+ }
+ }
+
+ }
+
+ private void startQueryDestinationFolders() {
+ String selection = NoteColumns.TYPE + "=? AND " + NoteColumns.PARENT_ID + "<>? AND " + NoteColumns.ID + "<>?";
+ selection = (mState == ListEditState.NOTE_LIST) ? selection:
+ "(" + selection + ") OR (" + NoteColumns.ID + "=" + Notes.ID_ROOT_FOLDER + ")";
+
+ mBackgroundQueryHandler.startQuery(FOLDER_LIST_QUERY_TOKEN,
+ null,
+ Notes.CONTENT_NOTE_URI,
+ FoldersListAdapter.PROJECTION,
+ selection,
+ new String[] {
+ String.valueOf(Notes.TYPE_FOLDER),
+ String.valueOf(Notes.ID_TRASH_FOLER),
+ String.valueOf(mCurrentFolderId)
+ },
+ NoteColumns.MODIFIED_DATE + " DESC");
+ }
+
+ public boolean onItemLongClick(AdapterView> parent, View view, int position, long id) {
+ if (view instanceof NotesListItem) {
+ mFocusNoteDataItem = ((NotesListItem) view).getItemData();
+ if (mFocusNoteDataItem.getType() == Notes.TYPE_NOTE && !mNotesListAdapter.isInChoiceMode()) {
+ if (mNotesListView.startActionMode(mModeCallBack) != null) {
+ mModeCallBack.onItemCheckedStateChanged(null, position, id, true);
+ mNotesListView.performHapticFeedback(HapticFeedbackConstants.LONG_PRESS);
+ } else {
+ Log.e(TAG, "startActionMode fails");
+ }
+ } else if (mFocusNoteDataItem.getType() == Notes.TYPE_FOLDER) {
+ mNotesListView.setOnCreateContextMenuListener(mFolderOnCreateContextMenuListener);
+ }
+ }
+ return false;
+ }
+}
diff --git a/src/src/Notes-master/src/net/micode/notes/ui/NotesListAdapter.java b/src/src/Notes-master/src/net/micode/notes/ui/NotesListAdapter.java
new file mode 100644
index 0000000..51c9cb9
--- /dev/null
+++ b/src/src/Notes-master/src/net/micode/notes/ui/NotesListAdapter.java
@@ -0,0 +1,184 @@
+/*
+ * Copyright (c) 2010-2011, The MiCode Open Source Community (www.micode.net)
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+
+package net.micode.notes.ui;
+
+import android.content.Context;
+import android.database.Cursor;
+import android.util.Log;
+import android.view.View;
+import android.view.ViewGroup;
+import android.widget.CursorAdapter;
+
+import net.micode.notes.data.Notes;
+
+import java.util.Collection;
+import java.util.HashMap;
+import java.util.HashSet;
+import java.util.Iterator;
+
+
+public class NotesListAdapter extends CursorAdapter {
+ private static final String TAG = "NotesListAdapter";
+ private Context mContext;
+ private HashMap mSelectedIndex;
+ private int mNotesCount;
+ private boolean mChoiceMode;
+
+ public static class AppWidgetAttribute {
+ public int widgetId;
+ public int widgetType;
+ };
+
+ public NotesListAdapter(Context context) {
+ super(context, null);
+ mSelectedIndex = new HashMap();
+ mContext = context;
+ mNotesCount = 0;
+ }
+
+ @Override
+ public View newView(Context context, Cursor cursor, ViewGroup parent) {
+ return new NotesListItem(context);
+ }
+
+ @Override
+ public void bindView(View view, Context context, Cursor cursor) {
+ if (view instanceof NotesListItem) {
+ NoteItemData itemData = new NoteItemData(context, cursor);
+ ((NotesListItem) view).bind(context, itemData, mChoiceMode,
+ isSelectedItem(cursor.getPosition()));
+ }
+ }
+
+ public void setCheckedItem(final int position, final boolean checked) {
+ mSelectedIndex.put(position, checked);
+ notifyDataSetChanged();
+ }
+
+ public boolean isInChoiceMode() {
+ return mChoiceMode;
+ }
+
+ public void setChoiceMode(boolean mode) {
+ mSelectedIndex.clear();
+ mChoiceMode = mode;
+ }
+
+ public void selectAll(boolean checked) {
+ Cursor cursor = getCursor();
+ for (int i = 0; i < getCount(); i++) {
+ if (cursor.moveToPosition(i)) {
+ if (NoteItemData.getNoteType(cursor) == Notes.TYPE_NOTE) {
+ setCheckedItem(i, checked);
+ }
+ }
+ }
+ }
+
+ public HashSet getSelectedItemIds() {
+ HashSet itemSet = new HashSet();
+ for (Integer position : mSelectedIndex.keySet()) {
+ if (mSelectedIndex.get(position) == true) {
+ Long id = getItemId(position);
+ if (id == Notes.ID_ROOT_FOLDER) {
+ Log.d(TAG, "Wrong item id, should not happen");
+ } else {
+ itemSet.add(id);
+ }
+ }
+ }
+
+ return itemSet;
+ }
+
+ public HashSet getSelectedWidget() {
+ HashSet itemSet = new HashSet();
+ for (Integer position : mSelectedIndex.keySet()) {
+ if (mSelectedIndex.get(position) == true) {
+ Cursor c = (Cursor) getItem(position);
+ if (c != null) {
+ AppWidgetAttribute widget = new AppWidgetAttribute();
+ NoteItemData item = new NoteItemData(mContext, c);
+ widget.widgetId = item.getWidgetId();
+ widget.widgetType = item.getWidgetType();
+ itemSet.add(widget);
+ /**
+ * Don't close cursor here, only the adapter could close it
+ */
+ } else {
+ Log.e(TAG, "Invalid cursor");
+ return null;
+ }
+ }
+ }
+ return itemSet;
+ }
+
+ public int getSelectedCount() {
+ Collection values = mSelectedIndex.values();
+ if (null == values) {
+ return 0;
+ }
+ Iterator iter = values.iterator();
+ int count = 0;
+ while (iter.hasNext()) {
+ if (true == iter.next()) {
+ count++;
+ }
+ }
+ return count;
+ }
+
+ public boolean isAllSelected() {
+ int checkedCount = getSelectedCount();
+ return (checkedCount != 0 && checkedCount == mNotesCount);
+ }
+
+ public boolean isSelectedItem(final int position) {
+ if (null == mSelectedIndex.get(position)) {
+ return false;
+ }
+ return mSelectedIndex.get(position);
+ }
+
+ @Override
+ protected void onContentChanged() {
+ super.onContentChanged();
+ calcNotesCount();
+ }
+
+ @Override
+ public void changeCursor(Cursor cursor) {
+ super.changeCursor(cursor);
+ calcNotesCount();
+ }
+
+ private void calcNotesCount() {
+ mNotesCount = 0;
+ for (int i = 0; i < getCount(); i++) {
+ Cursor c = (Cursor) getItem(i);
+ if (c != null) {
+ if (NoteItemData.getNoteType(c) == Notes.TYPE_NOTE) {
+ mNotesCount++;
+ }
+ } else {
+ Log.e(TAG, "Invalid cursor");
+ return;
+ }
+ }
+ }
+}
diff --git a/src/src/Notes-master/src/net/micode/notes/ui/NotesListItem.java b/src/src/Notes-master/src/net/micode/notes/ui/NotesListItem.java
new file mode 100644
index 0000000..1221e80
--- /dev/null
+++ b/src/src/Notes-master/src/net/micode/notes/ui/NotesListItem.java
@@ -0,0 +1,122 @@
+/*
+ * Copyright (c) 2010-2011, The MiCode Open Source Community (www.micode.net)
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+
+package net.micode.notes.ui;
+
+import android.content.Context;
+import android.text.format.DateUtils;
+import android.view.View;
+import android.widget.CheckBox;
+import android.widget.ImageView;
+import android.widget.LinearLayout;
+import android.widget.TextView;
+
+import net.micode.notes.R;
+import net.micode.notes.data.Notes;
+import net.micode.notes.tool.DataUtils;
+import net.micode.notes.tool.ResourceParser.NoteItemBgResources;
+
+
+public class NotesListItem extends LinearLayout {
+ private ImageView mAlert;
+ private TextView mTitle;
+ private TextView mTime;
+ private TextView mCallName;
+ private NoteItemData mItemData;
+ private CheckBox mCheckBox;
+
+ public NotesListItem(Context context) {
+ super(context);
+ inflate(context, R.layout.note_item, this);
+ mAlert = (ImageView) findViewById(R.id.iv_alert_icon);
+ mTitle = (TextView) findViewById(R.id.tv_title);
+ mTime = (TextView) findViewById(R.id.tv_time);
+ mCallName = (TextView) findViewById(R.id.tv_name);
+ mCheckBox = (CheckBox) findViewById(android.R.id.checkbox);
+ }
+
+ public void bind(Context context, NoteItemData data, boolean choiceMode, boolean checked) {
+ if (choiceMode && data.getType() == Notes.TYPE_NOTE) {
+ mCheckBox.setVisibility(View.VISIBLE);
+ mCheckBox.setChecked(checked);
+ } else {
+ mCheckBox.setVisibility(View.GONE);
+ }
+
+ mItemData = data;
+ if (data.getId() == Notes.ID_CALL_RECORD_FOLDER) {
+ mCallName.setVisibility(View.GONE);
+ mAlert.setVisibility(View.VISIBLE);
+ mTitle.setTextAppearance(context, R.style.TextAppearancePrimaryItem);
+ mTitle.setText(context.getString(R.string.call_record_folder_name)
+ + context.getString(R.string.format_folder_files_count, data.getNotesCount()));
+ mAlert.setImageResource(R.drawable.call_record);
+ } else if (data.getParentId() == Notes.ID_CALL_RECORD_FOLDER) {
+ mCallName.setVisibility(View.VISIBLE);
+ mCallName.setText(data.getCallName());
+ mTitle.setTextAppearance(context,R.style.TextAppearanceSecondaryItem);
+ mTitle.setText(DataUtils.getFormattedSnippet(data.getSnippet()));
+ if (data.hasAlert()) {
+ mAlert.setImageResource(R.drawable.clock);
+ mAlert.setVisibility(View.VISIBLE);
+ } else {
+ mAlert.setVisibility(View.GONE);
+ }
+ } else {
+ mCallName.setVisibility(View.GONE);
+ mTitle.setTextAppearance(context, R.style.TextAppearancePrimaryItem);
+
+ if (data.getType() == Notes.TYPE_FOLDER) {
+ mTitle.setText(data.getSnippet()
+ + context.getString(R.string.format_folder_files_count,
+ data.getNotesCount()));
+ mAlert.setVisibility(View.GONE);
+ } else {
+ mTitle.setText(DataUtils.getFormattedSnippet(data.getSnippet()));
+ if (data.hasAlert()) {
+ mAlert.setImageResource(R.drawable.clock);
+ mAlert.setVisibility(View.VISIBLE);
+ } else {
+ mAlert.setVisibility(View.GONE);
+ }
+ }
+ }
+ mTime.setText(DateUtils.getRelativeTimeSpanString(data.getModifiedDate()));
+
+ setBackground(data);
+ }
+
+ private void setBackground(NoteItemData data) {
+ int id = data.getBgColorId();
+ if (data.getType() == Notes.TYPE_NOTE) {
+ if (data.isSingle() || data.isOneFollowingFolder()) {
+ setBackgroundResource(NoteItemBgResources.getNoteBgSingleRes(id));
+ } else if (data.isLast()) {
+ setBackgroundResource(NoteItemBgResources.getNoteBgLastRes(id));
+ } else if (data.isFirst() || data.isMultiFollowingFolder()) {
+ setBackgroundResource(NoteItemBgResources.getNoteBgFirstRes(id));
+ } else {
+ setBackgroundResource(NoteItemBgResources.getNoteBgNormalRes(id));
+ }
+ } else {
+ setBackgroundResource(NoteItemBgResources.getFolderBgRes());
+ }
+ }
+
+ public NoteItemData getItemData() {
+ return mItemData;
+ }
+}
diff --git a/src/src/Notes-master/src/net/micode/notes/ui/NotesPreferenceActivity.java b/src/src/Notes-master/src/net/micode/notes/ui/NotesPreferenceActivity.java
new file mode 100644
index 0000000..07c5f7e
--- /dev/null
+++ b/src/src/Notes-master/src/net/micode/notes/ui/NotesPreferenceActivity.java
@@ -0,0 +1,388 @@
+/*
+ * Copyright (c) 2010-2011, The MiCode Open Source Community (www.micode.net)
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+
+package net.micode.notes.ui;
+
+import android.accounts.Account;
+import android.accounts.AccountManager;
+import android.app.ActionBar;
+import android.app.AlertDialog;
+import android.content.BroadcastReceiver;
+import android.content.ContentValues;
+import android.content.Context;
+import android.content.DialogInterface;
+import android.content.Intent;
+import android.content.IntentFilter;
+import android.content.SharedPreferences;
+import android.os.Bundle;
+import android.preference.Preference;
+import android.preference.Preference.OnPreferenceClickListener;
+import android.preference.PreferenceActivity;
+import android.preference.PreferenceCategory;
+import android.text.TextUtils;
+import android.text.format.DateFormat;
+import android.view.LayoutInflater;
+import android.view.Menu;
+import android.view.MenuItem;
+import android.view.View;
+import android.widget.Button;
+import android.widget.TextView;
+import android.widget.Toast;
+
+import net.micode.notes.R;
+import net.micode.notes.data.Notes;
+import net.micode.notes.data.Notes.NoteColumns;
+import net.micode.notes.gtask.remote.GTaskSyncService;
+
+
+public class NotesPreferenceActivity extends PreferenceActivity {
+ public static final String PREFERENCE_NAME = "notes_preferences";
+
+ public static final String PREFERENCE_SYNC_ACCOUNT_NAME = "pref_key_account_name";
+
+ public static final String PREFERENCE_LAST_SYNC_TIME = "pref_last_sync_time";
+
+ public static final String PREFERENCE_SET_BG_COLOR_KEY = "pref_key_bg_random_appear";
+
+ private static final String PREFERENCE_SYNC_ACCOUNT_KEY = "pref_sync_account_key";
+
+ private static final String AUTHORITIES_FILTER_KEY = "authorities";
+
+ private PreferenceCategory mAccountCategory;
+
+ private GTaskReceiver mReceiver;
+
+ private Account[] mOriAccounts;
+
+ private boolean mHasAddedAccount;
+
+ @Override
+ protected void onCreate(Bundle icicle) {
+ super.onCreate(icicle);
+
+ /* using the app icon for navigation */
+ getActionBar().setDisplayHomeAsUpEnabled(true);
+
+ addPreferencesFromResource(R.xml.preferences);
+ mAccountCategory = (PreferenceCategory) findPreference(PREFERENCE_SYNC_ACCOUNT_KEY);
+ mReceiver = new GTaskReceiver();
+ IntentFilter filter = new IntentFilter();
+ filter.addAction(GTaskSyncService.GTASK_SERVICE_BROADCAST_NAME);
+ registerReceiver(mReceiver, filter);
+
+ mOriAccounts = null;
+ View header = LayoutInflater.from(this).inflate(R.layout.settings_header, null);
+ getListView().addHeaderView(header, null, true);
+ }
+
+ @Override
+ protected void onResume() {
+ super.onResume();
+
+ // need to set sync account automatically if user has added a new
+ // account
+ if (mHasAddedAccount) {
+ Account[] accounts = getGoogleAccounts();
+ if (mOriAccounts != null && accounts.length > mOriAccounts.length) {
+ for (Account accountNew : accounts) {
+ boolean found = false;
+ for (Account accountOld : mOriAccounts) {
+ if (TextUtils.equals(accountOld.name, accountNew.name)) {
+ found = true;
+ break;
+ }
+ }
+ if (!found) {
+ setSyncAccount(accountNew.name);
+ break;
+ }
+ }
+ }
+ }
+
+ refreshUI();
+ }
+
+ @Override
+ protected void onDestroy() {
+ if (mReceiver != null) {
+ unregisterReceiver(mReceiver);
+ }
+ super.onDestroy();
+ }
+
+ private void loadAccountPreference() {
+ mAccountCategory.removeAll();
+
+ Preference accountPref = new Preference(this);
+ final String defaultAccount = getSyncAccountName(this);
+ accountPref.setTitle(getString(R.string.preferences_account_title));
+ accountPref.setSummary(getString(R.string.preferences_account_summary));
+ accountPref.setOnPreferenceClickListener(new OnPreferenceClickListener() {
+ public boolean onPreferenceClick(Preference preference) {
+ if (!GTaskSyncService.isSyncing()) {
+ if (TextUtils.isEmpty(defaultAccount)) {
+ // the first time to set account
+ showSelectAccountAlertDialog();
+ } else {
+ // if the account has already been set, we need to promp
+ // user about the risk
+ showChangeAccountConfirmAlertDialog();
+ }
+ } else {
+ Toast.makeText(NotesPreferenceActivity.this,
+ R.string.preferences_toast_cannot_change_account, Toast.LENGTH_SHORT)
+ .show();
+ }
+ return true;
+ }
+ });
+
+ mAccountCategory.addPreference(accountPref);
+ }
+
+ private void loadSyncButton() {
+ Button syncButton = (Button) findViewById(R.id.preference_sync_button);
+ TextView lastSyncTimeView = (TextView) findViewById(R.id.prefenerece_sync_status_textview);
+
+ // set button state
+ if (GTaskSyncService.isSyncing()) {
+ syncButton.setText(getString(R.string.preferences_button_sync_cancel));
+ syncButton.setOnClickListener(new View.OnClickListener() {
+ public void onClick(View v) {
+ GTaskSyncService.cancelSync(NotesPreferenceActivity.this);
+ }
+ });
+ } else {
+ syncButton.setText(getString(R.string.preferences_button_sync_immediately));
+ syncButton.setOnClickListener(new View.OnClickListener() {
+ public void onClick(View v) {
+ GTaskSyncService.startSync(NotesPreferenceActivity.this);
+ }
+ });
+ }
+ syncButton.setEnabled(!TextUtils.isEmpty(getSyncAccountName(this)));
+
+ // set last sync time
+ if (GTaskSyncService.isSyncing()) {
+ lastSyncTimeView.setText(GTaskSyncService.getProgressString());
+ lastSyncTimeView.setVisibility(View.VISIBLE);
+ } else {
+ long lastSyncTime = getLastSyncTime(this);
+ if (lastSyncTime != 0) {
+ lastSyncTimeView.setText(getString(R.string.preferences_last_sync_time,
+ DateFormat.format(getString(R.string.preferences_last_sync_time_format),
+ lastSyncTime)));
+ lastSyncTimeView.setVisibility(View.VISIBLE);
+ } else {
+ lastSyncTimeView.setVisibility(View.GONE);
+ }
+ }
+ }
+
+ private void refreshUI() {
+ loadAccountPreference();
+ loadSyncButton();
+ }
+
+ private void showSelectAccountAlertDialog() {
+ AlertDialog.Builder dialogBuilder = new AlertDialog.Builder(this);
+
+ View titleView = LayoutInflater.from(this).inflate(R.layout.account_dialog_title, null);
+ TextView titleTextView = (TextView) titleView.findViewById(R.id.account_dialog_title);
+ titleTextView.setText(getString(R.string.preferences_dialog_select_account_title));
+ TextView subtitleTextView = (TextView) titleView.findViewById(R.id.account_dialog_subtitle);
+ subtitleTextView.setText(getString(R.string.preferences_dialog_select_account_tips));
+
+ dialogBuilder.setCustomTitle(titleView);
+ dialogBuilder.setPositiveButton(null, null);
+
+ Account[] accounts = getGoogleAccounts();
+ String defAccount = getSyncAccountName(this);
+
+ mOriAccounts = accounts;
+ mHasAddedAccount = false;
+
+ if (accounts.length > 0) {
+ CharSequence[] items = new CharSequence[accounts.length];
+ final CharSequence[] itemMapping = items;
+ int checkedItem = -1;
+ int index = 0;
+ for (Account account : accounts) {
+ if (TextUtils.equals(account.name, defAccount)) {
+ checkedItem = index;
+ }
+ items[index++] = account.name;
+ }
+ dialogBuilder.setSingleChoiceItems(items, checkedItem,
+ new DialogInterface.OnClickListener() {
+ public void onClick(DialogInterface dialog, int which) {
+ setSyncAccount(itemMapping[which].toString());
+ dialog.dismiss();
+ refreshUI();
+ }
+ });
+ }
+
+ View addAccountView = LayoutInflater.from(this).inflate(R.layout.add_account_text, null);
+ dialogBuilder.setView(addAccountView);
+
+ final AlertDialog dialog = dialogBuilder.show();
+ addAccountView.setOnClickListener(new View.OnClickListener() {
+ public void onClick(View v) {
+ mHasAddedAccount = true;
+ Intent intent = new Intent("android.settings.ADD_ACCOUNT_SETTINGS");
+ intent.putExtra(AUTHORITIES_FILTER_KEY, new String[] {
+ "gmail-ls"
+ });
+ startActivityForResult(intent, -1);
+ dialog.dismiss();
+ }
+ });
+ }
+
+ private void showChangeAccountConfirmAlertDialog() {
+ AlertDialog.Builder dialogBuilder = new AlertDialog.Builder(this);
+
+ View titleView = LayoutInflater.from(this).inflate(R.layout.account_dialog_title, null);
+ TextView titleTextView = (TextView) titleView.findViewById(R.id.account_dialog_title);
+ titleTextView.setText(getString(R.string.preferences_dialog_change_account_title,
+ getSyncAccountName(this)));
+ TextView subtitleTextView = (TextView) titleView.findViewById(R.id.account_dialog_subtitle);
+ subtitleTextView.setText(getString(R.string.preferences_dialog_change_account_warn_msg));
+ dialogBuilder.setCustomTitle(titleView);
+
+ CharSequence[] menuItemArray = new CharSequence[] {
+ getString(R.string.preferences_menu_change_account),
+ getString(R.string.preferences_menu_remove_account),
+ getString(R.string.preferences_menu_cancel)
+ };
+ dialogBuilder.setItems(menuItemArray, new DialogInterface.OnClickListener() {
+ public void onClick(DialogInterface dialog, int which) {
+ if (which == 0) {
+ showSelectAccountAlertDialog();
+ } else if (which == 1) {
+ removeSyncAccount();
+ refreshUI();
+ }
+ }
+ });
+ dialogBuilder.show();
+ }
+
+ private Account[] getGoogleAccounts() {
+ AccountManager accountManager = AccountManager.get(this);
+ return accountManager.getAccountsByType("com.google");
+ }
+
+ private void setSyncAccount(String account) {
+ if (!getSyncAccountName(this).equals(account)) {
+ SharedPreferences settings = getSharedPreferences(PREFERENCE_NAME, Context.MODE_PRIVATE);
+ SharedPreferences.Editor editor = settings.edit();
+ if (account != null) {
+ editor.putString(PREFERENCE_SYNC_ACCOUNT_NAME, account);
+ } else {
+ editor.putString(PREFERENCE_SYNC_ACCOUNT_NAME, "");
+ }
+ editor.commit();
+
+ // clean up last sync time
+ setLastSyncTime(this, 0);
+
+ // clean up local gtask related info
+ new Thread(new Runnable() {
+ public void run() {
+ ContentValues values = new ContentValues();
+ values.put(NoteColumns.GTASK_ID, "");
+ values.put(NoteColumns.SYNC_ID, 0);
+ getContentResolver().update(Notes.CONTENT_NOTE_URI, values, null, null);
+ }
+ }).start();
+
+ Toast.makeText(NotesPreferenceActivity.this,
+ getString(R.string.preferences_toast_success_set_accout, account),
+ Toast.LENGTH_SHORT).show();
+ }
+ }
+
+ private void removeSyncAccount() {
+ SharedPreferences settings = getSharedPreferences(PREFERENCE_NAME, Context.MODE_PRIVATE);
+ SharedPreferences.Editor editor = settings.edit();
+ if (settings.contains(PREFERENCE_SYNC_ACCOUNT_NAME)) {
+ editor.remove(PREFERENCE_SYNC_ACCOUNT_NAME);
+ }
+ if (settings.contains(PREFERENCE_LAST_SYNC_TIME)) {
+ editor.remove(PREFERENCE_LAST_SYNC_TIME);
+ }
+ editor.commit();
+
+ // clean up local gtask related info
+ new Thread(new Runnable() {
+ public void run() {
+ ContentValues values = new ContentValues();
+ values.put(NoteColumns.GTASK_ID, "");
+ values.put(NoteColumns.SYNC_ID, 0);
+ getContentResolver().update(Notes.CONTENT_NOTE_URI, values, null, null);
+ }
+ }).start();
+ }
+
+ public static String getSyncAccountName(Context context) {
+ SharedPreferences settings = context.getSharedPreferences(PREFERENCE_NAME,
+ Context.MODE_PRIVATE);
+ return settings.getString(PREFERENCE_SYNC_ACCOUNT_NAME, "");
+ }
+
+ public static void setLastSyncTime(Context context, long time) {
+ SharedPreferences settings = context.getSharedPreferences(PREFERENCE_NAME,
+ Context.MODE_PRIVATE);
+ SharedPreferences.Editor editor = settings.edit();
+ editor.putLong(PREFERENCE_LAST_SYNC_TIME, time);
+ editor.commit();
+ }
+
+ public static long getLastSyncTime(Context context) {
+ SharedPreferences settings = context.getSharedPreferences(PREFERENCE_NAME,
+ Context.MODE_PRIVATE);
+ return settings.getLong(PREFERENCE_LAST_SYNC_TIME, 0);
+ }
+
+ private class GTaskReceiver extends BroadcastReceiver {
+
+ @Override
+ public void onReceive(Context context, Intent intent) {
+ refreshUI();
+ if (intent.getBooleanExtra(GTaskSyncService.GTASK_SERVICE_BROADCAST_IS_SYNCING, false)) {
+ TextView syncStatus = (TextView) findViewById(R.id.prefenerece_sync_status_textview);
+ syncStatus.setText(intent
+ .getStringExtra(GTaskSyncService.GTASK_SERVICE_BROADCAST_PROGRESS_MSG));
+ }
+
+ }
+ }
+
+ public boolean onOptionsItemSelected(MenuItem item) {
+ switch (item.getItemId()) {
+ case android.R.id.home:
+ Intent intent = new Intent(this, NotesListActivity.class);
+ intent.addFlags(Intent.FLAG_ACTIVITY_CLEAR_TOP);
+ startActivity(intent);
+ return true;
+ default:
+ return false;
+ }
+ }
+}
diff --git a/src/src/Notes-master/src/net/micode/notes/widget/NoteWidgetProvider.java b/src/src/Notes-master/src/net/micode/notes/widget/NoteWidgetProvider.java
new file mode 100644
index 0000000..ec6f819
--- /dev/null
+++ b/src/src/Notes-master/src/net/micode/notes/widget/NoteWidgetProvider.java
@@ -0,0 +1,132 @@
+/*
+ * Copyright (c) 2010-2011, The MiCode Open Source Community (www.micode.net)
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+
+package net.micode.notes.widget;
+import android.app.PendingIntent;
+import android.appwidget.AppWidgetManager;
+import android.appwidget.AppWidgetProvider;
+import android.content.ContentValues;
+import android.content.Context;
+import android.content.Intent;
+import android.database.Cursor;
+import android.util.Log;
+import android.widget.RemoteViews;
+
+import net.micode.notes.R;
+import net.micode.notes.data.Notes;
+import net.micode.notes.data.Notes.NoteColumns;
+import net.micode.notes.tool.ResourceParser;
+import net.micode.notes.ui.NoteEditActivity;
+import net.micode.notes.ui.NotesListActivity;
+
+public abstract class NoteWidgetProvider extends AppWidgetProvider {
+ public static final String [] PROJECTION = new String [] {
+ NoteColumns.ID,
+ NoteColumns.BG_COLOR_ID,
+ NoteColumns.SNIPPET
+ };
+
+ public static final int COLUMN_ID = 0;
+ public static final int COLUMN_BG_COLOR_ID = 1;
+ public static final int COLUMN_SNIPPET = 2;
+
+ private static final String TAG = "NoteWidgetProvider";
+
+ @Override
+ public void onDeleted(Context context, int[] appWidgetIds) {
+ ContentValues values = new ContentValues();
+ values.put(NoteColumns.WIDGET_ID, AppWidgetManager.INVALID_APPWIDGET_ID);
+ for (int i = 0; i < appWidgetIds.length; i++) {
+ context.getContentResolver().update(Notes.CONTENT_NOTE_URI,
+ values,
+ NoteColumns.WIDGET_ID + "=?",
+ new String[] { String.valueOf(appWidgetIds[i])});
+ }
+ }
+
+ private Cursor getNoteWidgetInfo(Context context, int widgetId) {
+ return context.getContentResolver().query(Notes.CONTENT_NOTE_URI,
+ PROJECTION,
+ NoteColumns.WIDGET_ID + "=? AND " + NoteColumns.PARENT_ID + "<>?",
+ new String[] { String.valueOf(widgetId), String.valueOf(Notes.ID_TRASH_FOLER) },
+ null);
+ }
+
+ protected void update(Context context, AppWidgetManager appWidgetManager, int[] appWidgetIds) {
+ update(context, appWidgetManager, appWidgetIds, false);
+ }
+
+ private void update(Context context, AppWidgetManager appWidgetManager, int[] appWidgetIds,
+ boolean privacyMode) {
+ for (int i = 0; i < appWidgetIds.length; i++) {
+ if (appWidgetIds[i] != AppWidgetManager.INVALID_APPWIDGET_ID) {
+ int bgId = ResourceParser.getDefaultBgId(context);
+ String snippet = "";
+ Intent intent = new Intent(context, NoteEditActivity.class);
+ intent.setFlags(Intent.FLAG_ACTIVITY_SINGLE_TOP);
+ intent.putExtra(Notes.INTENT_EXTRA_WIDGET_ID, appWidgetIds[i]);
+ intent.putExtra(Notes.INTENT_EXTRA_WIDGET_TYPE, getWidgetType());
+
+ Cursor c = getNoteWidgetInfo(context, appWidgetIds[i]);
+ if (c != null && c.moveToFirst()) {
+ if (c.getCount() > 1) {
+ Log.e(TAG, "Multiple message with same widget id:" + appWidgetIds[i]);
+ c.close();
+ return;
+ }
+ snippet = c.getString(COLUMN_SNIPPET);
+ bgId = c.getInt(COLUMN_BG_COLOR_ID);
+ intent.putExtra(Intent.EXTRA_UID, c.getLong(COLUMN_ID));
+ intent.setAction(Intent.ACTION_VIEW);
+ } else {
+ snippet = context.getResources().getString(R.string.widget_havenot_content);
+ intent.setAction(Intent.ACTION_INSERT_OR_EDIT);
+ }
+
+ if (c != null) {
+ c.close();
+ }
+
+ RemoteViews rv = new RemoteViews(context.getPackageName(), getLayoutId());
+ rv.setImageViewResource(R.id.widget_bg_image, getBgResourceId(bgId));
+ intent.putExtra(Notes.INTENT_EXTRA_BACKGROUND_ID, bgId);
+ /**
+ * Generate the pending intent to start host for the widget
+ */
+ PendingIntent pendingIntent = null;
+ if (privacyMode) {
+ rv.setTextViewText(R.id.widget_text,
+ context.getString(R.string.widget_under_visit_mode));
+ pendingIntent = PendingIntent.getActivity(context, appWidgetIds[i], new Intent(
+ context, NotesListActivity.class), PendingIntent.FLAG_UPDATE_CURRENT);
+ } else {
+ rv.setTextViewText(R.id.widget_text, snippet);
+ pendingIntent = PendingIntent.getActivity(context, appWidgetIds[i], intent,
+ PendingIntent.FLAG_UPDATE_CURRENT);
+ }
+
+ rv.setOnClickPendingIntent(R.id.widget_text, pendingIntent);
+ appWidgetManager.updateAppWidget(appWidgetIds[i], rv);
+ }
+ }
+ }
+
+ protected abstract int getBgResourceId(int bgId);
+
+ protected abstract int getLayoutId();
+
+ protected abstract int getWidgetType();
+}
diff --git a/src/src/Notes-master/src/net/micode/notes/widget/NoteWidgetProvider_2x.java b/src/src/Notes-master/src/net/micode/notes/widget/NoteWidgetProvider_2x.java
new file mode 100644
index 0000000..adcb2f7
--- /dev/null
+++ b/src/src/Notes-master/src/net/micode/notes/widget/NoteWidgetProvider_2x.java
@@ -0,0 +1,47 @@
+/*
+ * Copyright (c) 2010-2011, The MiCode Open Source Community (www.micode.net)
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+
+package net.micode.notes.widget;
+
+import android.appwidget.AppWidgetManager;
+import android.content.Context;
+
+import net.micode.notes.R;
+import net.micode.notes.data.Notes;
+import net.micode.notes.tool.ResourceParser;
+
+
+public class NoteWidgetProvider_2x extends NoteWidgetProvider {
+ @Override
+ public void onUpdate(Context context, AppWidgetManager appWidgetManager, int[] appWidgetIds) {
+ super.update(context, appWidgetManager, appWidgetIds);
+ }
+
+ @Override
+ protected int getLayoutId() {
+ return R.layout.widget_2x;
+ }
+
+ @Override
+ protected int getBgResourceId(int bgId) {
+ return ResourceParser.WidgetBgResources.getWidget2xBgResource(bgId);
+ }
+
+ @Override
+ protected int getWidgetType() {
+ return Notes.TYPE_WIDGET_2X;
+ }
+}
diff --git a/src/src/Notes-master/src/net/micode/notes/widget/NoteWidgetProvider_4x.java b/src/src/Notes-master/src/net/micode/notes/widget/NoteWidgetProvider_4x.java
new file mode 100644
index 0000000..c12a02e
--- /dev/null
+++ b/src/src/Notes-master/src/net/micode/notes/widget/NoteWidgetProvider_4x.java
@@ -0,0 +1,46 @@
+/*
+ * Copyright (c) 2010-2011, The MiCode Open Source Community (www.micode.net)
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+
+package net.micode.notes.widget;
+
+import android.appwidget.AppWidgetManager;
+import android.content.Context;
+
+import net.micode.notes.R;
+import net.micode.notes.data.Notes;
+import net.micode.notes.tool.ResourceParser;
+
+
+public class NoteWidgetProvider_4x extends NoteWidgetProvider {
+ @Override
+ public void onUpdate(Context context, AppWidgetManager appWidgetManager, int[] appWidgetIds) {
+ super.update(context, appWidgetManager, appWidgetIds);
+ }
+
+ protected int getLayoutId() {
+ return R.layout.widget_4x;
+ }
+
+ @Override
+ protected int getBgResourceId(int bgId) {
+ return ResourceParser.WidgetBgResources.getWidget4xBgResource(bgId);
+ }
+
+ @Override
+ protected int getWidgetType() {
+ return Notes.TYPE_WIDGET_4X;
+ }
+}
diff --git a/src/src/app/.classpath b/src/src/app/.classpath
new file mode 100644
index 0000000..4a04201
--- /dev/null
+++ b/src/src/app/.classpath
@@ -0,0 +1,6 @@
+
+
+
+
+
+
diff --git a/src/src/app/.project b/src/src/app/.project
new file mode 100644
index 0000000..54d1d4b
--- /dev/null
+++ b/src/src/app/.project
@@ -0,0 +1,34 @@
+
+
+ app
+ Project app created by Buildship.
+
+
+
+
+ org.eclipse.jdt.core.javabuilder
+
+
+
+
+ org.eclipse.buildship.core.gradleprojectbuilder
+
+
+
+
+
+ org.eclipse.jdt.core.javanature
+ org.eclipse.buildship.core.gradleprojectnature
+
+
+
+ 1614081047255
+
+ 30
+
+ org.eclipse.core.resources.regexFilterMatcher
+ node_modules|.git|__CREATED_BY_JAVA_LANGUAGE_SERVER__
+
+
+
+
diff --git a/src/src/app/.settings/org.eclipse.buildship.core.prefs b/src/src/app/.settings/org.eclipse.buildship.core.prefs
new file mode 100644
index 0000000..b1886ad
--- /dev/null
+++ b/src/src/app/.settings/org.eclipse.buildship.core.prefs
@@ -0,0 +1,2 @@
+connection.project.dir=..
+eclipse.preferences.version=1
diff --git a/src/src/app/build.gradle b/src/src/app/build.gradle
new file mode 100644
index 0000000..94d5769
--- /dev/null
+++ b/src/src/app/build.gradle
@@ -0,0 +1,26 @@
+apply plugin: 'com.android.application'
+
+android {
+ compileSdkVersion 28//API太低无法使用support——v4包
+ buildToolsVersion "30.0.2"
+ useLibrary'org.apache.http.legacy'
+
+ defaultConfig {
+ applicationId "net.micode.notes"
+ minSdkVersion 14
+ targetSdkVersion 28
+ }
+
+ buildTypes {
+ release {
+ minifyEnabled false
+ proguardFiles getDefaultProguardFile('proguard-android.txt'), 'proguard-rules.txt'
+ }
+ }
+}
+
+dependencies {
+ //noinspection GradleCompatible
+ implementation 'com.android.support:support-v4:28.0.0'//里面含有一些申请权限的方法
+ implementation 'androidx.appcompat:appcompat:1.0.0-alpha1'
+}
diff --git a/src/src/app/build/generated/source/buildConfig/androidTest/debug/net/micode/notes/test/BuildConfig.java b/src/src/app/build/generated/source/buildConfig/androidTest/debug/net/micode/notes/test/BuildConfig.java
new file mode 100644
index 0000000..19ee943
--- /dev/null
+++ b/src/src/app/build/generated/source/buildConfig/androidTest/debug/net/micode/notes/test/BuildConfig.java
@@ -0,0 +1,12 @@
+/**
+ * Automatically generated file. DO NOT MODIFY
+ */
+package net.micode.notes.test;
+
+public final class BuildConfig {
+ public static final boolean DEBUG = Boolean.parseBoolean("true");
+ public static final String APPLICATION_ID = "net.micode.notes.test";
+ public static final String BUILD_TYPE = "debug";
+ public static final int VERSION_CODE = -1;
+ public static final String VERSION_NAME = "";
+}
diff --git a/src/src/app/build/generated/source/buildConfig/debug/net/micode/notes/BuildConfig.java b/src/src/app/build/generated/source/buildConfig/debug/net/micode/notes/BuildConfig.java
new file mode 100644
index 0000000..db17690
--- /dev/null
+++ b/src/src/app/build/generated/source/buildConfig/debug/net/micode/notes/BuildConfig.java
@@ -0,0 +1,12 @@
+/**
+ * Automatically generated file. DO NOT MODIFY
+ */
+package net.micode.notes;
+
+public final class BuildConfig {
+ public static final boolean DEBUG = Boolean.parseBoolean("true");
+ public static final String APPLICATION_ID = "net.micode.notes";
+ public static final String BUILD_TYPE = "debug";
+ public static final int VERSION_CODE = 1;
+ public static final String VERSION_NAME = "0.1";
+}
diff --git a/src/src/app/build/intermediates/annotation_processor_list/debug/annotationProcessors.json b/src/src/app/build/intermediates/annotation_processor_list/debug/annotationProcessors.json
new file mode 100644
index 0000000..9e26dfe
--- /dev/null
+++ b/src/src/app/build/intermediates/annotation_processor_list/debug/annotationProcessors.json
@@ -0,0 +1 @@
+{}
\ No newline at end of file
diff --git a/src/src/app/build/intermediates/annotation_processor_list/debugAndroidTest/annotationProcessors.json b/src/src/app/build/intermediates/annotation_processor_list/debugAndroidTest/annotationProcessors.json
new file mode 100644
index 0000000..9e26dfe
--- /dev/null
+++ b/src/src/app/build/intermediates/annotation_processor_list/debugAndroidTest/annotationProcessors.json
@@ -0,0 +1 @@
+{}
\ No newline at end of file
diff --git a/src/src/app/build/intermediates/annotation_processor_list/debugUnitTest/annotationProcessors.json b/src/src/app/build/intermediates/annotation_processor_list/debugUnitTest/annotationProcessors.json
new file mode 100644
index 0000000..9e26dfe
--- /dev/null
+++ b/src/src/app/build/intermediates/annotation_processor_list/debugUnitTest/annotationProcessors.json
@@ -0,0 +1 @@
+{}
\ No newline at end of file
diff --git a/src/src/app/build/intermediates/app_classes/debug/classes.jar b/src/src/app/build/intermediates/app_classes/debug/classes.jar
new file mode 100644
index 0000000..49970ac
Binary files /dev/null and b/src/src/app/build/intermediates/app_classes/debug/classes.jar differ
diff --git a/src/src/app/build/intermediates/blame/res/debug/multi-v2/debug.json b/src/src/app/build/intermediates/blame/res/debug/multi-v2/debug.json
new file mode 100644
index 0000000..85e514b
--- /dev/null
+++ b/src/src/app/build/intermediates/blame/res/debug/multi-v2/debug.json
@@ -0,0 +1,3372 @@
+{
+ "logs": [
+ {
+ "outputFile": "E:\\Note\\src\\app\\build\\intermediates\\res\\merged\\debug\\values-or_values-or.arsc.flat",
+ "map": [
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\88c548461109b0c917067cfea58751b3\\appcompat-1.0.0-alpha1\\res\\values-or\\values-or.xml",
+ "from": {
+ "startLines": "2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19,20,21,22,23,24,25,26,27,28,29",
+ "startColumns": "4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4",
+ "startOffsets": "105,224,334,441,527,631,751,828,905,996,1089,1186,1281,1382,1475,1570,1666,1757,1847,1929,2039,2144,2250,2361,2464,2582,2745,2847",
+ "endColumns": "118,109,106,85,103,119,76,76,90,92,96,94,100,92,94,95,90,89,81,109,104,105,110,102,117,162,101,88",
+ "endOffsets": "219,329,436,522,626,746,823,900,991,1084,1181,1276,1377,1470,1565,1661,1752,1842,1924,2034,2139,2245,2356,2459,2577,2740,2842,2931"
+ }
+ },
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\6d11613c3b6a00a9ea456b5609ec43f7\\core-1.0.0\\res\\values-or\\values-or.xml",
+ "from": {
+ "startLines": "2",
+ "startColumns": "4",
+ "startOffsets": "55",
+ "endColumns": "100",
+ "endOffsets": "151"
+ },
+ "to": {
+ "startLines": "30",
+ "startColumns": "4",
+ "startOffsets": "2936",
+ "endColumns": "100",
+ "endOffsets": "3032"
+ }
+ }
+ ]
+ },
+ {
+ "outputFile": "E:\\Note\\src\\app\\build\\intermediates\\res\\merged\\debug\\values-et_values-et.arsc.flat",
+ "map": [
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\88c548461109b0c917067cfea58751b3\\appcompat-1.0.0-alpha1\\res\\values-et\\values-et.xml",
+ "from": {
+ "startLines": "2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19,20,21,22,23,24,25,26,27,28,29",
+ "startColumns": "4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4",
+ "startOffsets": "105,222,329,440,526,628,745,825,903,995,1089,1194,1296,1406,1500,1601,1695,1787,1880,1963,2074,2179,2278,2388,2489,2592,2758,2860",
+ "endColumns": "116,106,110,85,101,116,79,77,91,93,104,101,109,93,100,93,91,92,82,110,104,98,109,100,102,165,101,81",
+ "endOffsets": "217,324,435,521,623,740,820,898,990,1084,1189,1291,1401,1495,1596,1690,1782,1875,1958,2069,2174,2273,2383,2484,2587,2753,2855,2937"
+ }
+ },
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\6d11613c3b6a00a9ea456b5609ec43f7\\core-1.0.0\\res\\values-et\\values-et.xml",
+ "from": {
+ "startLines": "2",
+ "startColumns": "4",
+ "startOffsets": "55",
+ "endColumns": "100",
+ "endOffsets": "151"
+ },
+ "to": {
+ "startLines": "30",
+ "startColumns": "4",
+ "startOffsets": "2942",
+ "endColumns": "100",
+ "endOffsets": "3038"
+ }
+ }
+ ]
+ },
+ {
+ "outputFile": "E:\\Note\\src\\app\\build\\intermediates\\res\\merged\\debug\\values-pt-rPT_values-pt-rPT.arsc.flat",
+ "map": [
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\6d11613c3b6a00a9ea456b5609ec43f7\\core-1.0.0\\res\\values-pt-rPT\\values-pt-rPT.xml",
+ "from": {
+ "startLines": "2",
+ "startColumns": "4",
+ "startOffsets": "55",
+ "endColumns": "100",
+ "endOffsets": "151"
+ },
+ "to": {
+ "startLines": "30",
+ "startColumns": "4",
+ "startOffsets": "2949",
+ "endColumns": "100",
+ "endOffsets": "3045"
+ }
+ },
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\88c548461109b0c917067cfea58751b3\\appcompat-1.0.0-alpha1\\res\\values-pt-rPT\\values-pt-rPT.xml",
+ "from": {
+ "startLines": "2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19,20,21,22,23,24,25,26,27,28,29",
+ "startColumns": "4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4",
+ "startOffsets": "105,225,331,438,527,628,752,836,917,1009,1103,1201,1295,1395,1489,1585,1680,1772,1864,1951,2058,2170,2272,2380,2487,2594,2765,2864",
+ "endColumns": "119,105,106,88,100,123,83,80,91,93,97,93,99,93,95,94,91,91,86,106,111,101,107,106,106,170,98,84",
+ "endOffsets": "220,326,433,522,623,747,831,912,1004,1098,1196,1290,1390,1484,1580,1675,1767,1859,1946,2053,2165,2267,2375,2482,2589,2760,2859,2944"
+ }
+ }
+ ]
+ },
+ {
+ "outputFile": "E:\\Note\\src\\app\\build\\intermediates\\res\\merged\\debug\\values-ta_values-ta.arsc.flat",
+ "map": [
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\88c548461109b0c917067cfea58751b3\\appcompat-1.0.0-alpha1\\res\\values-ta\\values-ta.xml",
+ "from": {
+ "startLines": "2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19,20,21,22,23,24,25,26,27,28,29",
+ "startColumns": "4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4",
+ "startOffsets": "105,219,317,432,521,628,754,832,909,1009,1114,1210,1305,1412,1514,1618,1713,1815,1913,1995,2097,2201,2298,2408,2510,2617,2774,2874",
+ "endColumns": "113,97,114,88,106,125,77,76,99,104,95,94,106,101,103,94,101,97,81,101,103,96,109,101,106,156,99,79",
+ "endOffsets": "214,312,427,516,623,749,827,904,1004,1109,1205,1300,1407,1509,1613,1708,1810,1908,1990,2092,2196,2293,2403,2505,2612,2769,2869,2949"
+ }
+ },
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\6d11613c3b6a00a9ea456b5609ec43f7\\core-1.0.0\\res\\values-ta\\values-ta.xml",
+ "from": {
+ "startLines": "2",
+ "startColumns": "4",
+ "startOffsets": "55",
+ "endColumns": "100",
+ "endOffsets": "151"
+ },
+ "to": {
+ "startLines": "30",
+ "startColumns": "4",
+ "startOffsets": "2954",
+ "endColumns": "100",
+ "endOffsets": "3050"
+ }
+ }
+ ]
+ },
+ {
+ "outputFile": "E:\\Note\\src\\app\\build\\intermediates\\res\\merged\\debug\\values-hu_values-hu.arsc.flat",
+ "map": [
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\6d11613c3b6a00a9ea456b5609ec43f7\\core-1.0.0\\res\\values-hu\\values-hu.xml",
+ "from": {
+ "startLines": "2",
+ "startColumns": "4",
+ "startOffsets": "55",
+ "endColumns": "100",
+ "endOffsets": "151"
+ },
+ "to": {
+ "startLines": "30",
+ "startColumns": "4",
+ "startOffsets": "2961",
+ "endColumns": "100",
+ "endOffsets": "3057"
+ }
+ },
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\88c548461109b0c917067cfea58751b3\\appcompat-1.0.0-alpha1\\res\\values-hu\\values-hu.xml",
+ "from": {
+ "startLines": "2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19,20,21,22,23,24,25,26,27,28,29",
+ "startColumns": "4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4",
+ "startOffsets": "105,213,318,433,517,629,759,835,911,1002,1095,1191,1285,1386,1479,1574,1669,1760,1851,1934,2044,2155,2255,2366,2474,2593,2775,2878",
+ "endColumns": "107,104,114,83,111,129,75,75,90,92,95,93,100,92,94,94,90,90,82,109,110,99,110,107,118,181,102,82",
+ "endOffsets": "208,313,428,512,624,754,830,906,997,1090,1186,1280,1381,1474,1569,1664,1755,1846,1929,2039,2150,2250,2361,2469,2588,2770,2873,2956"
+ }
+ }
+ ]
+ },
+ {
+ "outputFile": "E:\\Note\\src\\app\\build\\intermediates\\res\\merged\\debug\\values-hdpi-v4_values-hdpi-v4.arsc.flat",
+ "map": [
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\88c548461109b0c917067cfea58751b3\\appcompat-1.0.0-alpha1\\res\\values-hdpi-v4\\values-hdpi-v4.xml",
+ "from": {
+ "startLines": "2",
+ "startColumns": "4",
+ "startOffsets": "55",
+ "endLines": "6",
+ "endColumns": "13",
+ "endOffsets": "327"
+ }
+ }
+ ]
+ },
+ {
+ "outputFile": "E:\\Note\\src\\app\\build\\intermediates\\res\\merged\\debug\\values-en-rGB_values-en-rGB.arsc.flat",
+ "map": [
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\88c548461109b0c917067cfea58751b3\\appcompat-1.0.0-alpha1\\res\\values-en-rGB\\values-en-rGB.xml",
+ "from": {
+ "startLines": "2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19,20,21,22,23,24,25,26,27,28,29",
+ "startColumns": "4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4",
+ "startOffsets": "105,209,309,417,501,601,716,793,869,960,1053,1149,1243,1344,1437,1532,1626,1717,1808,1890,1993,2097,2196,2301,2404,2508,2664,2764",
+ "endColumns": "103,99,107,83,99,114,76,75,90,92,95,93,100,92,94,93,90,90,81,102,103,98,104,102,103,155,99,81",
+ "endOffsets": "204,304,412,496,596,711,788,864,955,1048,1144,1238,1339,1432,1527,1621,1712,1803,1885,1988,2092,2191,2296,2399,2503,2659,2759,2841"
+ }
+ },
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\6d11613c3b6a00a9ea456b5609ec43f7\\core-1.0.0\\res\\values-en-rGB\\values-en-rGB.xml",
+ "from": {
+ "startLines": "2",
+ "startColumns": "4",
+ "startOffsets": "55",
+ "endColumns": "100",
+ "endOffsets": "151"
+ },
+ "to": {
+ "startLines": "30",
+ "startColumns": "4",
+ "startOffsets": "2846",
+ "endColumns": "100",
+ "endOffsets": "2942"
+ }
+ }
+ ]
+ },
+ {
+ "outputFile": "E:\\Note\\src\\app\\build\\intermediates\\res\\merged\\debug\\values-sw600dp-v13_values-sw600dp-v13.arsc.flat",
+ "map": [
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\88c548461109b0c917067cfea58751b3\\appcompat-1.0.0-alpha1\\res\\values-sw600dp-v13\\values-sw600dp-v13.xml",
+ "from": {
+ "startLines": "2,3,4,5,6,7,8,9",
+ "startColumns": "4,4,4,4,4,4,4,4",
+ "startOffsets": "55,124,193,263,337,413,472,543",
+ "endColumns": "68,68,69,73,75,58,70,67",
+ "endOffsets": "119,188,258,332,408,467,538,606"
+ }
+ }
+ ]
+ },
+ {
+ "outputFile": "E:\\Note\\src\\app\\build\\intermediates\\res\\merged\\debug\\values-km_values-km.arsc.flat",
+ "map": [
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\6d11613c3b6a00a9ea456b5609ec43f7\\core-1.0.0\\res\\values-km\\values-km.xml",
+ "from": {
+ "startLines": "2",
+ "startColumns": "4",
+ "startOffsets": "55",
+ "endColumns": "100",
+ "endOffsets": "151"
+ },
+ "to": {
+ "startLines": "30",
+ "startColumns": "4",
+ "startOffsets": "2882",
+ "endColumns": "100",
+ "endOffsets": "2978"
+ }
+ },
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\88c548461109b0c917067cfea58751b3\\appcompat-1.0.0-alpha1\\res\\values-km\\values-km.xml",
+ "from": {
+ "startLines": "2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19,20,21,22,23,24,25,26,27,28,29",
+ "startColumns": "4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4",
+ "startOffsets": "105,208,308,420,507,611,729,806,883,974,1067,1163,1257,1358,1451,1546,1640,1731,1822,1905,2009,2114,2214,2324,2431,2539,2701,2799",
+ "endColumns": "102,99,111,86,103,117,76,76,90,92,95,93,100,92,94,93,90,90,82,103,104,99,109,106,107,161,97,82",
+ "endOffsets": "203,303,415,502,606,724,801,878,969,1062,1158,1252,1353,1446,1541,1635,1726,1817,1900,2004,2109,2209,2319,2426,2534,2696,2794,2877"
+ }
+ }
+ ]
+ },
+ {
+ "outputFile": "E:\\Note\\src\\app\\build\\intermediates\\res\\merged\\debug\\values-v18_values-v18.arsc.flat",
+ "map": [
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\88c548461109b0c917067cfea58751b3\\appcompat-1.0.0-alpha1\\res\\values-v18\\values-v18.xml",
+ "from": {
+ "startLines": "2",
+ "startColumns": "4",
+ "startOffsets": "55",
+ "endColumns": "48",
+ "endOffsets": "99"
+ }
+ }
+ ]
+ },
+ {
+ "outputFile": "E:\\Note\\src\\app\\build\\intermediates\\res\\merged\\debug\\values-uk_values-uk.arsc.flat",
+ "map": [
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\6d11613c3b6a00a9ea456b5609ec43f7\\core-1.0.0\\res\\values-uk\\values-uk.xml",
+ "from": {
+ "startLines": "2",
+ "startColumns": "4",
+ "startOffsets": "55",
+ "endColumns": "100",
+ "endOffsets": "151"
+ },
+ "to": {
+ "startLines": "30",
+ "startColumns": "4",
+ "startOffsets": "2900",
+ "endColumns": "100",
+ "endOffsets": "2996"
+ }
+ },
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\88c548461109b0c917067cfea58751b3\\appcompat-1.0.0-alpha1\\res\\values-uk\\values-uk.xml",
+ "from": {
+ "startLines": "2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19,20,21,22,23,24,25,26,27,28,29",
+ "startColumns": "4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4",
+ "startOffsets": "105,215,317,423,509,617,735,814,894,985,1078,1174,1268,1369,1462,1557,1652,1743,1834,1915,2021,2128,2226,2334,2440,2549,2719,2819",
+ "endColumns": "109,101,105,85,107,117,78,79,90,92,95,93,100,92,94,94,90,90,80,105,106,97,107,105,108,169,99,80",
+ "endOffsets": "210,312,418,504,612,730,809,889,980,1073,1169,1263,1364,1457,1552,1647,1738,1829,1910,2016,2123,2221,2329,2435,2544,2714,2814,2895"
+ }
+ }
+ ]
+ },
+ {
+ "outputFile": "E:\\Note\\src\\app\\build\\intermediates\\res\\merged\\debug\\values-h720dp-v13_values-h720dp-v13.arsc.flat",
+ "map": [
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\88c548461109b0c917067cfea58751b3\\appcompat-1.0.0-alpha1\\res\\values-h720dp-v13\\values-h720dp-v13.xml",
+ "from": {
+ "startLines": "2",
+ "startColumns": "4",
+ "startOffsets": "55",
+ "endColumns": "66",
+ "endOffsets": "117"
+ }
+ }
+ ]
+ },
+ {
+ "outputFile": "E:\\Note\\src\\app\\build\\intermediates\\res\\merged\\debug\\values-cs_values-cs.arsc.flat",
+ "map": [
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\88c548461109b0c917067cfea58751b3\\appcompat-1.0.0-alpha1\\res\\values-cs\\values-cs.xml",
+ "from": {
+ "startLines": "2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19,20,21,22,23,24,25,26,27,28,29",
+ "startColumns": "4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4",
+ "startOffsets": "105,212,314,423,509,614,731,812,893,984,1077,1173,1267,1362,1455,1550,1647,1738,1829,1913,2017,2126,2225,2331,2441,2548,2711,2809",
+ "endColumns": "106,101,108,85,104,116,80,80,90,92,95,93,94,92,94,96,90,90,83,103,108,98,105,109,106,162,97,81",
+ "endOffsets": "207,309,418,504,609,726,807,888,979,1072,1168,1262,1357,1450,1545,1642,1733,1824,1908,2012,2121,2220,2326,2436,2543,2706,2804,2886"
+ }
+ },
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\6d11613c3b6a00a9ea456b5609ec43f7\\core-1.0.0\\res\\values-cs\\values-cs.xml",
+ "from": {
+ "startLines": "2",
+ "startColumns": "4",
+ "startOffsets": "55",
+ "endColumns": "100",
+ "endOffsets": "151"
+ },
+ "to": {
+ "startLines": "30",
+ "startColumns": "4",
+ "startOffsets": "2891",
+ "endColumns": "100",
+ "endOffsets": "2987"
+ }
+ }
+ ]
+ },
+ {
+ "outputFile": "E:\\Note\\src\\app\\build\\intermediates\\res\\merged\\debug\\values-land_values-land.arsc.flat",
+ "map": [
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\88c548461109b0c917067cfea58751b3\\appcompat-1.0.0-alpha1\\res\\values-land\\values-land.xml",
+ "from": {
+ "startLines": "2,3,4",
+ "startColumns": "4,4,4",
+ "startOffsets": "55,125,196",
+ "endColumns": "69,70,67",
+ "endOffsets": "120,191,259"
+ }
+ }
+ ]
+ },
+ {
+ "outputFile": "E:\\Note\\src\\app\\build\\intermediates\\res\\merged\\debug\\values-ro_values-ro.arsc.flat",
+ "map": [
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\6d11613c3b6a00a9ea456b5609ec43f7\\core-1.0.0\\res\\values-ro\\values-ro.xml",
+ "from": {
+ "startLines": "2",
+ "startColumns": "4",
+ "startOffsets": "55",
+ "endColumns": "100",
+ "endOffsets": "151"
+ },
+ "to": {
+ "startLines": "30",
+ "startColumns": "4",
+ "startOffsets": "2953",
+ "endColumns": "100",
+ "endOffsets": "3049"
+ }
+ },
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\88c548461109b0c917067cfea58751b3\\appcompat-1.0.0-alpha1\\res\\values-ro\\values-ro.xml",
+ "from": {
+ "startLines": "2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19,20,21,22,23,24,25,26,27,28,29",
+ "startColumns": "4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4",
+ "startOffsets": "105,226,330,443,531,643,764,849,930,1021,1114,1210,1304,1404,1497,1592,1687,1778,1870,1953,2065,2178,2278,2392,2497,2603,2767,2870",
+ "endColumns": "120,103,112,87,111,120,84,80,90,92,95,93,99,92,94,94,90,91,82,111,112,99,113,104,105,163,102,82",
+ "endOffsets": "221,325,438,526,638,759,844,925,1016,1109,1205,1299,1399,1492,1587,1682,1773,1865,1948,2060,2173,2273,2387,2492,2598,2762,2865,2948"
+ }
+ }
+ ]
+ },
+ {
+ "outputFile": "E:\\Note\\src\\app\\build\\intermediates\\res\\merged\\debug\\values-bs_values-bs.arsc.flat",
+ "map": [
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\88c548461109b0c917067cfea58751b3\\appcompat-1.0.0-alpha1\\res\\values-bs\\values-bs.xml",
+ "from": {
+ "startLines": "2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19,20,21,22,23,24,25,26,27,28,29",
+ "startColumns": "4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4",
+ "startOffsets": "105,224,333,440,526,630,752,834,915,1006,1099,1195,1289,1390,1483,1578,1677,1768,1859,1945,2048,2153,2251,2356,2469,2572,2745,2842",
+ "endColumns": "118,108,106,85,103,121,81,80,90,92,95,93,100,92,94,98,90,90,85,102,104,97,104,112,102,172,96,83",
+ "endOffsets": "219,328,435,521,625,747,829,910,1001,1094,1190,1284,1385,1478,1573,1672,1763,1854,1940,2043,2148,2246,2351,2464,2567,2740,2837,2921"
+ }
+ },
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\6d11613c3b6a00a9ea456b5609ec43f7\\core-1.0.0\\res\\values-bs\\values-bs.xml",
+ "from": {
+ "startLines": "2",
+ "startColumns": "4",
+ "startOffsets": "55",
+ "endColumns": "100",
+ "endOffsets": "151"
+ },
+ "to": {
+ "startLines": "30",
+ "startColumns": "4",
+ "startOffsets": "2926",
+ "endColumns": "100",
+ "endOffsets": "3022"
+ }
+ }
+ ]
+ },
+ {
+ "outputFile": "E:\\Note\\src\\app\\build\\intermediates\\res\\merged\\debug\\values-zh-rHK_values-zh-rHK.arsc.flat",
+ "map": [
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\88c548461109b0c917067cfea58751b3\\appcompat-1.0.0-alpha1\\res\\values-zh-rHK\\values-zh-rHK.xml",
+ "from": {
+ "startLines": "2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19,20,21,22,23,24,25,26,27,28,29",
+ "startColumns": "4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4",
+ "startOffsets": "105,200,293,393,475,572,680,756,832,924,1018,1110,1206,1302,1396,1492,1584,1676,1768,1846,1942,2038,2133,2230,2325,2423,2574,2668",
+ "endColumns": "94,92,99,81,96,107,75,75,91,93,91,95,95,93,95,91,91,91,77,95,95,94,96,94,97,150,93,77",
+ "endOffsets": "195,288,388,470,567,675,751,827,919,1013,1105,1201,1297,1391,1487,1579,1671,1763,1841,1937,2033,2128,2225,2320,2418,2569,2663,2741"
+ }
+ },
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\6d11613c3b6a00a9ea456b5609ec43f7\\core-1.0.0\\res\\values-zh-rHK\\values-zh-rHK.xml",
+ "from": {
+ "startLines": "2",
+ "startColumns": "4",
+ "startOffsets": "55",
+ "endColumns": "100",
+ "endOffsets": "151"
+ },
+ "to": {
+ "startLines": "30",
+ "startColumns": "4",
+ "startOffsets": "2746",
+ "endColumns": "100",
+ "endOffsets": "2842"
+ }
+ }
+ ]
+ },
+ {
+ "outputFile": "E:\\Note\\src\\app\\build\\intermediates\\res\\merged\\debug\\values-as_values-as.arsc.flat",
+ "map": [
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\6d11613c3b6a00a9ea456b5609ec43f7\\core-1.0.0\\res\\values-as\\values-as.xml",
+ "from": {
+ "startLines": "2",
+ "startColumns": "4",
+ "startOffsets": "55",
+ "endColumns": "100",
+ "endOffsets": "151"
+ },
+ "to": {
+ "startLines": "30",
+ "startColumns": "4",
+ "startOffsets": "2950",
+ "endColumns": "100",
+ "endOffsets": "3046"
+ }
+ },
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\88c548461109b0c917067cfea58751b3\\appcompat-1.0.0-alpha1\\res\\values-as\\values-as.xml",
+ "from": {
+ "startLines": "2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19,20,21,22,23,24,25,26,27,28,29",
+ "startColumns": "4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4",
+ "startOffsets": "105,213,312,419,515,617,736,816,896,987,1080,1173,1268,1368,1461,1558,1652,1743,1834,1923,2025,2140,2243,2352,2471,2591,2758,2861",
+ "endColumns": "107,98,106,95,101,118,79,79,90,92,92,94,99,92,96,93,90,90,88,101,114,102,108,118,119,166,102,88",
+ "endOffsets": "208,307,414,510,612,731,811,891,982,1075,1168,1263,1363,1456,1553,1647,1738,1829,1918,2020,2135,2238,2347,2466,2586,2753,2856,2945"
+ }
+ }
+ ]
+ },
+ {
+ "outputFile": "E:\\Note\\src\\app\\build\\intermediates\\res\\merged\\debug\\values-zu_values-zu.arsc.flat",
+ "map": [
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\88c548461109b0c917067cfea58751b3\\appcompat-1.0.0-alpha1\\res\\values-zu\\values-zu.xml",
+ "from": {
+ "startLines": "2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19,20,21,22,23,24,25,26,27,28,29",
+ "startColumns": "4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4",
+ "startOffsets": "105,213,320,434,522,625,752,832,912,1003,1096,1190,1284,1385,1478,1573,1667,1758,1851,1937,2041,2147,2245,2352,2458,2564,2721,2817",
+ "endColumns": "107,106,113,87,102,126,79,79,90,92,93,93,100,92,94,93,90,92,85,103,105,97,106,105,105,156,95,80",
+ "endOffsets": "208,315,429,517,620,747,827,907,998,1091,1185,1279,1380,1473,1568,1662,1753,1846,1932,2036,2142,2240,2347,2453,2559,2716,2812,2893"
+ }
+ },
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\6d11613c3b6a00a9ea456b5609ec43f7\\core-1.0.0\\res\\values-zu\\values-zu.xml",
+ "from": {
+ "startLines": "2",
+ "startColumns": "4",
+ "startOffsets": "55",
+ "endColumns": "100",
+ "endOffsets": "151"
+ },
+ "to": {
+ "startLines": "30",
+ "startColumns": "4",
+ "startOffsets": "2898",
+ "endColumns": "100",
+ "endOffsets": "2994"
+ }
+ }
+ ]
+ },
+ {
+ "outputFile": "E:\\Note\\src\\app\\build\\intermediates\\res\\merged\\debug\\values-hy_values-hy.arsc.flat",
+ "map": [
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\6d11613c3b6a00a9ea456b5609ec43f7\\core-1.0.0\\res\\values-hy\\values-hy.xml",
+ "from": {
+ "startLines": "2",
+ "startColumns": "4",
+ "startOffsets": "55",
+ "endColumns": "100",
+ "endOffsets": "151"
+ },
+ "to": {
+ "startLines": "30",
+ "startColumns": "4",
+ "startOffsets": "2884",
+ "endColumns": "100",
+ "endOffsets": "2980"
+ }
+ },
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\88c548461109b0c917067cfea58751b3\\appcompat-1.0.0-alpha1\\res\\values-hy\\values-hy.xml",
+ "from": {
+ "startLines": "2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19,20,21,22,23,24,25,26,27,28,29",
+ "startColumns": "4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4",
+ "startOffsets": "105,208,309,419,508,614,729,811,892,983,1076,1172,1266,1367,1460,1555,1649,1740,1831,1916,2023,2130,2229,2339,2446,2546,2703,2802",
+ "endColumns": "102,100,109,88,105,114,81,80,90,92,95,93,100,92,94,93,90,90,84,106,106,98,109,106,99,156,98,81",
+ "endOffsets": "203,304,414,503,609,724,806,887,978,1071,1167,1261,1362,1455,1550,1644,1735,1826,1911,2018,2125,2224,2334,2441,2541,2698,2797,2879"
+ }
+ }
+ ]
+ },
+ {
+ "outputFile": "E:\\Note\\src\\app\\build\\intermediates\\res\\merged\\debug\\values-fr-rCA_values-fr-rCA.arsc.flat",
+ "map": [
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\88c548461109b0c917067cfea58751b3\\appcompat-1.0.0-alpha1\\res\\values-fr-rCA\\values-fr-rCA.xml",
+ "from": {
+ "startLines": "2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19,20,21,22,23,24,25,26,27,28,29",
+ "startColumns": "4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4",
+ "startOffsets": "105,216,331,442,529,645,775,858,938,1029,1122,1221,1316,1417,1510,1603,1698,1789,1880,1976,2086,2198,2301,2412,2519,2621,2780,2879",
+ "endColumns": "110,114,110,86,115,129,82,79,90,92,98,94,100,92,92,94,90,90,95,109,111,102,110,106,101,158,98,85",
+ "endOffsets": "211,326,437,524,640,770,853,933,1024,1117,1216,1311,1412,1505,1598,1693,1784,1875,1971,2081,2193,2296,2407,2514,2616,2775,2874,2960"
+ }
+ },
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\6d11613c3b6a00a9ea456b5609ec43f7\\core-1.0.0\\res\\values-fr-rCA\\values-fr-rCA.xml",
+ "from": {
+ "startLines": "2",
+ "startColumns": "4",
+ "startOffsets": "55",
+ "endColumns": "100",
+ "endOffsets": "151"
+ },
+ "to": {
+ "startLines": "30",
+ "startColumns": "4",
+ "startOffsets": "2965",
+ "endColumns": "100",
+ "endOffsets": "3061"
+ }
+ }
+ ]
+ },
+ {
+ "outputFile": "E:\\Note\\src\\app\\build\\intermediates\\res\\merged\\debug\\values-port_values-port.arsc.flat",
+ "map": [
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\88c548461109b0c917067cfea58751b3\\appcompat-1.0.0-alpha1\\res\\values-port\\values-port.xml",
+ "from": {
+ "startLines": "2",
+ "startColumns": "4",
+ "startOffsets": "55",
+ "endColumns": "55",
+ "endOffsets": "106"
+ }
+ }
+ ]
+ },
+ {
+ "outputFile": "E:\\Note\\src\\app\\build\\intermediates\\res\\merged\\debug\\values-tr_values-tr.arsc.flat",
+ "map": [
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\6d11613c3b6a00a9ea456b5609ec43f7\\core-1.0.0\\res\\values-tr\\values-tr.xml",
+ "from": {
+ "startLines": "2",
+ "startColumns": "4",
+ "startOffsets": "55",
+ "endColumns": "100",
+ "endOffsets": "151"
+ },
+ "to": {
+ "startLines": "30",
+ "startColumns": "4",
+ "startOffsets": "2865",
+ "endColumns": "100",
+ "endOffsets": "2961"
+ }
+ },
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\88c548461109b0c917067cfea58751b3\\appcompat-1.0.0-alpha1\\res\\values-tr\\values-tr.xml",
+ "from": {
+ "startLines": "2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19,20,21,22,23,24,25,26,27,28,29",
+ "startColumns": "4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4",
+ "startOffsets": "105,210,309,421,506,612,732,811,887,978,1071,1164,1258,1356,1449,1551,1646,1737,1828,1907,2014,2119,2215,2322,2424,2532,2688,2786",
+ "endColumns": "104,98,111,84,105,119,78,75,90,92,92,93,97,92,101,94,90,90,78,106,104,95,106,101,107,155,97,78",
+ "endOffsets": "205,304,416,501,607,727,806,882,973,1066,1159,1253,1351,1444,1546,1641,1732,1823,1902,2009,2114,2210,2317,2419,2527,2683,2781,2860"
+ }
+ }
+ ]
+ },
+ {
+ "outputFile": "E:\\Note\\src\\app\\build\\intermediates\\res\\merged\\debug\\values-ar_values-ar.arsc.flat",
+ "map": [
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\6d11613c3b6a00a9ea456b5609ec43f7\\core-1.0.0\\res\\values-ar\\values-ar.xml",
+ "from": {
+ "startLines": "2",
+ "startColumns": "4",
+ "startOffsets": "55",
+ "endColumns": "100",
+ "endOffsets": "151"
+ },
+ "to": {
+ "startLines": "30",
+ "startColumns": "4",
+ "startOffsets": "2860",
+ "endColumns": "100",
+ "endOffsets": "2956"
+ }
+ },
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\88c548461109b0c917067cfea58751b3\\appcompat-1.0.0-alpha1\\res\\values-ar\\values-ar.xml",
+ "from": {
+ "startLines": "2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19,20,21,22,23,24,25,26,27,28,29",
+ "startColumns": "4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4",
+ "startOffsets": "105,222,326,435,517,618,732,811,890,981,1074,1170,1264,1365,1458,1553,1647,1738,1832,1911,2016,2117,2213,2321,2424,2527,2682,2779",
+ "endColumns": "116,103,108,81,100,113,78,78,90,92,95,93,100,92,94,93,90,93,78,104,100,95,107,102,102,154,96,80",
+ "endOffsets": "217,321,430,512,613,727,806,885,976,1069,1165,1259,1360,1453,1548,1642,1733,1827,1906,2011,2112,2208,2316,2419,2522,2677,2774,2855"
+ }
+ }
+ ]
+ },
+ {
+ "outputFile": "E:\\Note\\src\\app\\build\\intermediates\\res\\merged\\debug\\values-es_values-es.arsc.flat",
+ "map": [
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\6d11613c3b6a00a9ea456b5609ec43f7\\core-1.0.0\\res\\values-es\\values-es.xml",
+ "from": {
+ "startLines": "2",
+ "startColumns": "4",
+ "startOffsets": "55",
+ "endColumns": "100",
+ "endOffsets": "151"
+ },
+ "to": {
+ "startLines": "30",
+ "startColumns": "4",
+ "startOffsets": "2924",
+ "endColumns": "100",
+ "endOffsets": "3020"
+ }
+ },
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\88c548461109b0c917067cfea58751b3\\appcompat-1.0.0-alpha1\\res\\values-es\\values-es.xml",
+ "from": {
+ "startLines": "2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19,20,21,22,23,24,25,26,27,28,29",
+ "startColumns": "4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4",
+ "startOffsets": "105,222,335,443,528,629,757,842,924,1016,1110,1208,1302,1403,1497,1593,1689,1781,1873,1955,2062,2162,2261,2369,2476,2583,2742,2842",
+ "endColumns": "116,112,107,84,100,127,84,81,91,93,97,93,100,93,95,95,91,91,81,106,99,98,107,106,106,158,99,81",
+ "endOffsets": "217,330,438,523,624,752,837,919,1011,1105,1203,1297,1398,1492,1588,1684,1776,1868,1950,2057,2157,2256,2364,2471,2578,2737,2837,2919"
+ }
+ }
+ ]
+ },
+ {
+ "outputFile": "E:\\Note\\src\\app\\build\\intermediates\\res\\merged\\debug\\values-watch-v21_values-watch-v21.arsc.flat",
+ "map": [
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\88c548461109b0c917067cfea58751b3\\appcompat-1.0.0-alpha1\\res\\values-watch-v21\\values-watch-v21.xml",
+ "from": {
+ "startLines": "2,6,10",
+ "startColumns": "4,4,4",
+ "startOffsets": "55,271,499",
+ "endLines": "5,9,13",
+ "endColumns": "12,12,12",
+ "endOffsets": "266,494,724"
+ }
+ }
+ ]
+ },
+ {
+ "outputFile": "E:\\Note\\src\\app\\build\\intermediates\\res\\merged\\debug\\values-bg_values-bg.arsc.flat",
+ "map": [
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\6d11613c3b6a00a9ea456b5609ec43f7\\core-1.0.0\\res\\values-bg\\values-bg.xml",
+ "from": {
+ "startLines": "2",
+ "startColumns": "4",
+ "startOffsets": "55",
+ "endColumns": "100",
+ "endOffsets": "151"
+ },
+ "to": {
+ "startLines": "30",
+ "startColumns": "4",
+ "startOffsets": "2930",
+ "endColumns": "100",
+ "endOffsets": "3026"
+ }
+ },
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\88c548461109b0c917067cfea58751b3\\appcompat-1.0.0-alpha1\\res\\values-bg\\values-bg.xml",
+ "from": {
+ "startLines": "2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19,20,21,22,23,24,25,26,27,28,29",
+ "startColumns": "4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4",
+ "startOffsets": "105,220,327,432,518,623,744,823,901,992,1085,1181,1275,1376,1469,1564,1672,1763,1854,1937,2051,2160,2260,2374,2480,2588,2748,2847",
+ "endColumns": "114,106,104,85,104,120,78,77,90,92,95,93,100,92,94,107,90,90,82,113,108,99,113,105,107,159,98,82",
+ "endOffsets": "215,322,427,513,618,739,818,896,987,1080,1176,1270,1371,1464,1559,1667,1758,1849,1932,2046,2155,2255,2369,2475,2583,2743,2842,2925"
+ }
+ }
+ ]
+ },
+ {
+ "outputFile": "E:\\Note\\src\\app\\build\\intermediates\\res\\merged\\debug\\values-mn_values-mn.arsc.flat",
+ "map": [
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\6d11613c3b6a00a9ea456b5609ec43f7\\core-1.0.0\\res\\values-mn\\values-mn.xml",
+ "from": {
+ "startLines": "2",
+ "startColumns": "4",
+ "startOffsets": "55",
+ "endColumns": "100",
+ "endOffsets": "151"
+ },
+ "to": {
+ "startLines": "30",
+ "startColumns": "4",
+ "startOffsets": "2876",
+ "endColumns": "100",
+ "endOffsets": "2972"
+ }
+ },
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\88c548461109b0c917067cfea58751b3\\appcompat-1.0.0-alpha1\\res\\values-mn\\values-mn.xml",
+ "from": {
+ "startLines": "2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19,20,21,22,23,24,25,26,27,28,29",
+ "startColumns": "4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4",
+ "startOffsets": "105,218,318,431,518,624,736,818,900,991,1084,1180,1276,1374,1467,1562,1654,1745,1835,1917,2026,2130,2227,2335,2436,2539,2698,2795",
+ "endColumns": "112,99,112,86,105,111,81,81,90,92,95,95,97,92,94,91,90,89,81,108,103,96,107,100,102,158,96,80",
+ "endOffsets": "213,313,426,513,619,731,813,895,986,1079,1175,1271,1369,1462,1557,1649,1740,1830,1912,2021,2125,2222,2330,2431,2534,2693,2790,2871"
+ }
+ }
+ ]
+ },
+ {
+ "outputFile": "E:\\Note\\src\\app\\build\\intermediates\\res\\merged\\debug\\values-nl_values-nl.arsc.flat",
+ "map": [
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\88c548461109b0c917067cfea58751b3\\appcompat-1.0.0-alpha1\\res\\values-nl\\values-nl.xml",
+ "from": {
+ "startLines": "2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19,20,21,22,23,24,25,26,27,28,29",
+ "startColumns": "4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4",
+ "startOffsets": "105,223,328,435,521,629,749,826,903,995,1089,1190,1284,1385,1479,1575,1670,1762,1854,1936,2047,2151,2250,2365,2478,2581,2736,2839",
+ "endColumns": "117,104,106,85,107,119,76,76,91,93,100,93,100,93,95,94,91,91,81,110,103,98,114,112,102,154,102,81",
+ "endOffsets": "218,323,430,516,624,744,821,898,990,1084,1185,1279,1380,1474,1570,1665,1757,1849,1931,2042,2146,2245,2360,2473,2576,2731,2834,2916"
+ }
+ },
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\6d11613c3b6a00a9ea456b5609ec43f7\\core-1.0.0\\res\\values-nl\\values-nl.xml",
+ "from": {
+ "startLines": "2",
+ "startColumns": "4",
+ "startOffsets": "55",
+ "endColumns": "100",
+ "endOffsets": "151"
+ },
+ "to": {
+ "startLines": "30",
+ "startColumns": "4",
+ "startOffsets": "2921",
+ "endColumns": "100",
+ "endOffsets": "3017"
+ }
+ }
+ ]
+ },
+ {
+ "outputFile": "E:\\Note\\src\\app\\build\\intermediates\\res\\merged\\debug\\values-be_values-be.arsc.flat",
+ "map": [
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\6d11613c3b6a00a9ea456b5609ec43f7\\core-1.0.0\\res\\values-be\\values-be.xml",
+ "from": {
+ "startLines": "2",
+ "startColumns": "4",
+ "startOffsets": "55",
+ "endColumns": "100",
+ "endOffsets": "151"
+ },
+ "to": {
+ "startLines": "30",
+ "startColumns": "4",
+ "startOffsets": "2915",
+ "endColumns": "100",
+ "endOffsets": "3011"
+ }
+ },
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\88c548461109b0c917067cfea58751b3\\appcompat-1.0.0-alpha1\\res\\values-be\\values-be.xml",
+ "from": {
+ "startLines": "2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19,20,21,22,23,24,25,26,27,28,29",
+ "startColumns": "4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4",
+ "startOffsets": "105,225,328,444,530,638,756,835,913,1005,1099,1195,1289,1385,1479,1575,1670,1762,1854,1937,2043,2149,2247,2355,2460,2565,2734,2834",
+ "endColumns": "119,102,115,85,107,117,78,77,91,93,95,93,95,93,95,94,91,91,82,105,105,97,107,104,104,168,99,80",
+ "endOffsets": "220,323,439,525,633,751,830,908,1000,1094,1190,1284,1380,1474,1570,1665,1757,1849,1932,2038,2144,2242,2350,2455,2560,2729,2829,2910"
+ }
+ }
+ ]
+ },
+ {
+ "outputFile": "E:\\Note\\src\\app\\build\\intermediates\\res\\merged\\debug\\values-it_values-it.arsc.flat",
+ "map": [
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\6d11613c3b6a00a9ea456b5609ec43f7\\core-1.0.0\\res\\values-it\\values-it.xml",
+ "from": {
+ "startLines": "2",
+ "startColumns": "4",
+ "startOffsets": "55",
+ "endColumns": "100",
+ "endOffsets": "151"
+ },
+ "to": {
+ "startLines": "30",
+ "startColumns": "4",
+ "startOffsets": "2906",
+ "endColumns": "100",
+ "endOffsets": "3002"
+ }
+ },
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\88c548461109b0c917067cfea58751b3\\appcompat-1.0.0-alpha1\\res\\values-it\\values-it.xml",
+ "from": {
+ "startLines": "2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19,20,21,22,23,24,25,26,27,28,29",
+ "startColumns": "4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4",
+ "startOffsets": "105,214,314,423,507,616,741,818,894,986,1080,1174,1268,1370,1464,1561,1667,1759,1851,1932,2038,2146,2244,2348,2453,2560,2723,2823",
+ "endColumns": "108,99,108,83,108,124,76,75,91,93,93,93,101,93,96,105,91,91,80,105,107,97,103,104,106,162,99,82",
+ "endOffsets": "209,309,418,502,611,736,813,889,981,1075,1169,1263,1365,1459,1556,1662,1754,1846,1927,2033,2141,2239,2343,2448,2555,2718,2818,2901"
+ }
+ }
+ ]
+ },
+ {
+ "outputFile": "E:\\Note\\src\\app\\build\\intermediates\\res\\merged\\debug\\values-sk_values-sk.arsc.flat",
+ "map": [
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\6d11613c3b6a00a9ea456b5609ec43f7\\core-1.0.0\\res\\values-sk\\values-sk.xml",
+ "from": {
+ "startLines": "2",
+ "startColumns": "4",
+ "startOffsets": "55",
+ "endColumns": "100",
+ "endOffsets": "151"
+ },
+ "to": {
+ "startLines": "30",
+ "startColumns": "4",
+ "startOffsets": "2918",
+ "endColumns": "100",
+ "endOffsets": "3014"
+ }
+ },
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\88c548461109b0c917067cfea58751b3\\appcompat-1.0.0-alpha1\\res\\values-sk\\values-sk.xml",
+ "from": {
+ "startLines": "2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19,20,21,22,23,24,25,26,27,28,29",
+ "startColumns": "4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4",
+ "startOffsets": "105,212,312,423,509,617,735,816,897,988,1081,1180,1274,1375,1468,1563,1661,1752,1843,1927,2032,2141,2240,2346,2457,2566,2732,2830",
+ "endColumns": "106,99,110,85,107,117,80,80,90,92,98,93,100,92,94,97,90,90,83,104,108,98,105,110,108,165,97,87",
+ "endOffsets": "207,307,418,504,612,730,811,892,983,1076,1175,1269,1370,1463,1558,1656,1747,1838,1922,2027,2136,2235,2341,2452,2561,2727,2825,2913"
+ }
+ }
+ ]
+ },
+ {
+ "outputFile": "E:\\Note\\src\\app\\build\\intermediates\\res\\merged\\debug\\values-my_values-my.arsc.flat",
+ "map": [
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\88c548461109b0c917067cfea58751b3\\appcompat-1.0.0-alpha1\\res\\values-my\\values-my.xml",
+ "from": {
+ "startLines": "2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19,20,21,22,23,24,25,26,27,28,29",
+ "startColumns": "4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4",
+ "startOffsets": "105,214,319,436,529,641,769,847,926,1017,1110,1206,1300,1401,1494,1589,1683,1774,1865,1951,2074,2186,2288,2414,2525,2635,2795,2895",
+ "endColumns": "108,104,116,92,111,127,77,78,90,92,95,93,100,92,94,93,90,90,85,122,111,101,125,110,109,159,99,83",
+ "endOffsets": "209,314,431,524,636,764,842,921,1012,1105,1201,1295,1396,1489,1584,1678,1769,1860,1946,2069,2181,2283,2409,2520,2630,2790,2890,2974"
+ }
+ },
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\6d11613c3b6a00a9ea456b5609ec43f7\\core-1.0.0\\res\\values-my\\values-my.xml",
+ "from": {
+ "startLines": "2",
+ "startColumns": "4",
+ "startOffsets": "55",
+ "endColumns": "100",
+ "endOffsets": "151"
+ },
+ "to": {
+ "startLines": "30",
+ "startColumns": "4",
+ "startOffsets": "2979",
+ "endColumns": "100",
+ "endOffsets": "3075"
+ }
+ }
+ ]
+ },
+ {
+ "outputFile": "E:\\Note\\src\\app\\build\\intermediates\\res\\merged\\debug\\values-xlarge-v4_values-xlarge-v4.arsc.flat",
+ "map": [
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\88c548461109b0c917067cfea58751b3\\appcompat-1.0.0-alpha1\\res\\values-xlarge-v4\\values-xlarge-v4.xml",
+ "from": {
+ "startLines": "2,3,4,5,6,7",
+ "startColumns": "4,4,4,4,4,4",
+ "startOffsets": "55,126,197,267,337,405",
+ "endColumns": "70,70,69,69,67,67",
+ "endOffsets": "121,192,262,332,400,468"
+ }
+ }
+ ]
+ },
+ {
+ "outputFile": "E:\\Note\\src\\app\\build\\intermediates\\res\\merged\\debug\\values-en-rXC_values-en-rXC.arsc.flat",
+ "map": [
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\88c548461109b0c917067cfea58751b3\\appcompat-1.0.0-alpha1\\res\\values-en-rXC\\values-en-rXC.xml",
+ "from": {
+ "startLines": "2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19,20,21,22,23,24,25,26,27,28,29",
+ "startColumns": "4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4",
+ "startOffsets": "105,310,510,719,904,1106,1321,1494,1671,1862,2055,2253,2449,2652,2847,3044,3239,3432,3623,3807,4011,4216,4417,4624,4826,5031,5303,5503",
+ "endColumns": "204,199,208,184,201,214,172,176,190,192,197,195,202,194,196,194,192,190,183,203,204,200,206,201,204,271,199,178",
+ "endOffsets": "305,505,714,899,1101,1316,1489,1666,1857,2050,2248,2444,2647,2842,3039,3234,3427,3618,3802,4006,4211,4412,4619,4821,5026,5298,5498,5677"
+ }
+ },
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\6d11613c3b6a00a9ea456b5609ec43f7\\core-1.0.0\\res\\values-en-rXC\\values-en-rXC.xml",
+ "from": {
+ "startLines": "2",
+ "startColumns": "4",
+ "startOffsets": "55",
+ "endColumns": "202",
+ "endOffsets": "253"
+ },
+ "to": {
+ "startLines": "30",
+ "startColumns": "4",
+ "startOffsets": "5682",
+ "endColumns": "202",
+ "endOffsets": "5880"
+ }
+ }
+ ]
+ },
+ {
+ "outputFile": "E:\\Note\\src\\app\\build\\intermediates\\res\\merged\\debug\\values-kn_values-kn.arsc.flat",
+ "map": [
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\88c548461109b0c917067cfea58751b3\\appcompat-1.0.0-alpha1\\res\\values-kn\\values-kn.xml",
+ "from": {
+ "startLines": "2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19,20,21,22,23,24,25,26,27,28,29",
+ "startColumns": "4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4",
+ "startOffsets": "105,223,335,448,536,643,770,847,924,1015,1108,1204,1298,1399,1492,1587,1681,1772,1863,1945,2061,2172,2271,2384,2488,2602,2766,2866",
+ "endColumns": "117,111,112,87,106,126,76,76,90,92,95,93,100,92,94,93,90,90,81,115,110,98,112,103,113,163,99,81",
+ "endOffsets": "218,330,443,531,638,765,842,919,1010,1103,1199,1293,1394,1487,1582,1676,1767,1858,1940,2056,2167,2266,2379,2483,2597,2761,2861,2943"
+ }
+ },
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\6d11613c3b6a00a9ea456b5609ec43f7\\core-1.0.0\\res\\values-kn\\values-kn.xml",
+ "from": {
+ "startLines": "2",
+ "startColumns": "4",
+ "startOffsets": "55",
+ "endColumns": "100",
+ "endOffsets": "151"
+ },
+ "to": {
+ "startLines": "30",
+ "startColumns": "4",
+ "startOffsets": "2948",
+ "endColumns": "100",
+ "endOffsets": "3044"
+ }
+ }
+ ]
+ },
+ {
+ "outputFile": "E:\\Note\\src\\app\\build\\intermediates\\res\\merged\\debug\\values-b+sr+Latn_values-b+sr+Latn.arsc.flat",
+ "map": [
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\6d11613c3b6a00a9ea456b5609ec43f7\\core-1.0.0\\res\\values-b+sr+Latn\\values-b+sr+Latn.xml",
+ "from": {
+ "startLines": "2",
+ "startColumns": "4",
+ "startOffsets": "55",
+ "endColumns": "100",
+ "endOffsets": "151"
+ },
+ "to": {
+ "startLines": "30",
+ "startColumns": "4",
+ "startOffsets": "2912",
+ "endColumns": "100",
+ "endOffsets": "3008"
+ }
+ },
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\88c548461109b0c917067cfea58751b3\\appcompat-1.0.0-alpha1\\res\\values-b+sr+Latn\\values-b+sr+Latn.xml",
+ "from": {
+ "startLines": "2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19,20,21,22,23,24,25,26,27,28,29",
+ "startColumns": "4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4",
+ "startOffsets": "105,214,318,424,510,614,732,814,895,986,1079,1175,1269,1370,1463,1558,1663,1754,1845,1933,2039,2147,2248,2353,2461,2562,2731,2828",
+ "endColumns": "108,103,105,85,103,117,81,80,90,92,95,93,100,92,94,104,90,90,87,105,107,100,104,107,100,168,96,83",
+ "endOffsets": "209,313,419,505,609,727,809,890,981,1074,1170,1264,1365,1458,1553,1658,1749,1840,1928,2034,2142,2243,2348,2456,2557,2726,2823,2907"
+ }
+ }
+ ]
+ },
+ {
+ "outputFile": "E:\\Note\\src\\app\\build\\intermediates\\res\\merged\\debug\\values-da_values-da.arsc.flat",
+ "map": [
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\6d11613c3b6a00a9ea456b5609ec43f7\\core-1.0.0\\res\\values-da\\values-da.xml",
+ "from": {
+ "startLines": "2",
+ "startColumns": "4",
+ "startOffsets": "55",
+ "endColumns": "100",
+ "endOffsets": "151"
+ },
+ "to": {
+ "startLines": "30",
+ "startColumns": "4",
+ "startOffsets": "2844",
+ "endColumns": "100",
+ "endOffsets": "2940"
+ }
+ },
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\88c548461109b0c917067cfea58751b3\\appcompat-1.0.0-alpha1\\res\\values-da\\values-da.xml",
+ "from": {
+ "startLines": "2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19,20,21,22,23,24,25,26,27,28,29",
+ "startColumns": "4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4",
+ "startOffsets": "105,208,307,419,502,602,715,792,869,960,1053,1149,1243,1338,1431,1526,1624,1715,1806,1885,1994,2102,2198,2312,2414,2515,2668,2765",
+ "endColumns": "102,98,111,82,99,112,76,76,90,92,95,93,94,92,94,97,90,90,78,108,107,95,113,101,100,152,96,78",
+ "endOffsets": "203,302,414,497,597,710,787,864,955,1048,1144,1238,1333,1426,1521,1619,1710,1801,1880,1989,2097,2193,2307,2409,2510,2663,2760,2839"
+ }
+ }
+ ]
+ },
+ {
+ "outputFile": "E:\\Note\\src\\app\\build\\intermediates\\res\\merged\\debug\\values-te_values-te.arsc.flat",
+ "map": [
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\88c548461109b0c917067cfea58751b3\\appcompat-1.0.0-alpha1\\res\\values-te\\values-te.xml",
+ "from": {
+ "startLines": "2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19,20,21,22,23,24,25,26,27,28,29",
+ "startColumns": "4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4",
+ "startOffsets": "105,219,328,439,529,634,759,841,923,1014,1107,1203,1297,1398,1491,1586,1681,1772,1863,1947,2060,2168,2267,2378,2480,2597,2763,2864",
+ "endColumns": "113,108,110,89,104,124,81,81,90,92,95,93,100,92,94,94,90,90,83,112,107,98,110,101,116,165,100,81",
+ "endOffsets": "214,323,434,524,629,754,836,918,1009,1102,1198,1292,1393,1486,1581,1676,1767,1858,1942,2055,2163,2262,2373,2475,2592,2758,2859,2941"
+ }
+ },
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\6d11613c3b6a00a9ea456b5609ec43f7\\core-1.0.0\\res\\values-te\\values-te.xml",
+ "from": {
+ "startLines": "2",
+ "startColumns": "4",
+ "startOffsets": "55",
+ "endColumns": "100",
+ "endOffsets": "151"
+ },
+ "to": {
+ "startLines": "30",
+ "startColumns": "4",
+ "startOffsets": "2946",
+ "endColumns": "100",
+ "endOffsets": "3042"
+ }
+ }
+ ]
+ },
+ {
+ "outputFile": "E:\\Note\\src\\app\\build\\intermediates\\res\\merged\\debug\\values-ky_values-ky.arsc.flat",
+ "map": [
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\6d11613c3b6a00a9ea456b5609ec43f7\\core-1.0.0\\res\\values-ky\\values-ky.xml",
+ "from": {
+ "startLines": "2",
+ "startColumns": "4",
+ "startOffsets": "55",
+ "endColumns": "100",
+ "endOffsets": "151"
+ },
+ "to": {
+ "startLines": "30",
+ "startColumns": "4",
+ "startOffsets": "2883",
+ "endColumns": "100",
+ "endOffsets": "2979"
+ }
+ },
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\88c548461109b0c917067cfea58751b3\\appcompat-1.0.0-alpha1\\res\\values-ky\\values-ky.xml",
+ "from": {
+ "startLines": "2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19,20,21,22,23,24,25,26,27,28,29",
+ "startColumns": "4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4",
+ "startOffsets": "105,209,304,423,507,614,731,809,888,979,1072,1168,1262,1363,1456,1551,1646,1737,1828,1909,2019,2126,2224,2330,2437,2538,2699,2802",
+ "endColumns": "103,94,118,83,106,116,77,78,90,92,95,93,100,92,94,94,90,90,80,109,106,97,105,106,100,160,102,80",
+ "endOffsets": "204,299,418,502,609,726,804,883,974,1067,1163,1257,1358,1451,1546,1641,1732,1823,1904,2014,2121,2219,2325,2432,2533,2694,2797,2878"
+ }
+ }
+ ]
+ },
+ {
+ "outputFile": "E:\\Note\\src\\app\\build\\intermediates\\res\\merged\\debug\\values-v17_values-v17.arsc.flat",
+ "map": [
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\88c548461109b0c917067cfea58751b3\\appcompat-1.0.0-alpha1\\res\\values-v17\\values-v17.xml",
+ "from": {
+ "startLines": "2,5,9,12,15,18,22,25,29,33,37,40,43,46,50,53,57",
+ "startColumns": "4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4",
+ "startOffsets": "55,228,456,614,764,936,1161,1331,1559,1783,2025,2196,2370,2539,2812,3012,3216",
+ "endLines": "4,8,11,14,17,21,24,28,32,36,39,42,45,49,52,56,60",
+ "endColumns": "12,12,12,12,12,12,12,12,12,12,12,12,12,12,12,12,12",
+ "endOffsets": "223,451,609,759,931,1156,1326,1554,1778,2020,2191,2365,2534,2807,3007,3211,3540"
+ }
+ }
+ ]
+ },
+ {
+ "outputFile": "E:\\Note\\src\\app\\build\\intermediates\\res\\merged\\debug\\values-am_values-am.arsc.flat",
+ "map": [
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\6d11613c3b6a00a9ea456b5609ec43f7\\core-1.0.0\\res\\values-am\\values-am.xml",
+ "from": {
+ "startLines": "2",
+ "startColumns": "4",
+ "startOffsets": "55",
+ "endColumns": "100",
+ "endOffsets": "151"
+ },
+ "to": {
+ "startLines": "30",
+ "startColumns": "4",
+ "startOffsets": "2817",
+ "endColumns": "100",
+ "endOffsets": "2913"
+ }
+ },
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\88c548461109b0c917067cfea58751b3\\appcompat-1.0.0-alpha1\\res\\values-am\\values-am.xml",
+ "from": {
+ "startLines": "2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19,20,21,22,23,24,25,26,27,28,29",
+ "startColumns": "4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4",
+ "startOffsets": "105,207,306,412,498,601,714,792,870,961,1054,1147,1241,1342,1435,1530,1624,1715,1805,1884,1984,2084,2180,2283,2382,2489,2642,2738",
+ "endColumns": "101,98,105,85,102,112,77,77,90,92,92,93,100,92,94,93,90,89,78,99,99,95,102,98,106,152,95,78",
+ "endOffsets": "202,301,407,493,596,709,787,865,956,1049,1142,1236,1337,1430,1525,1619,1710,1800,1879,1979,2079,2175,2278,2377,2484,2637,2733,2812"
+ }
+ }
+ ]
+ },
+ {
+ "outputFile": "E:\\Note\\src\\app\\build\\intermediates\\res\\merged\\debug\\values-pt-rBR_values-pt-rBR.arsc.flat",
+ "map": [
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\88c548461109b0c917067cfea58751b3\\appcompat-1.0.0-alpha1\\res\\values-pt-rBR\\values-pt-rBR.xml",
+ "from": {
+ "startLines": "2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19,20,21,22,23,24,25,26,27,28,29",
+ "startColumns": "4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4",
+ "startOffsets": "105,225,331,438,527,628,746,829,909,1000,1093,1189,1283,1384,1477,1572,1667,1758,1849,1936,2043,2155,2257,2365,2472,2582,2744,2844",
+ "endColumns": "119,105,106,88,100,117,82,79,90,92,95,93,100,92,94,94,90,90,86,106,111,101,107,106,109,161,99,84",
+ "endOffsets": "220,326,433,522,623,741,824,904,995,1088,1184,1278,1379,1472,1567,1662,1753,1844,1931,2038,2150,2252,2360,2467,2577,2739,2839,2924"
+ }
+ },
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\6d11613c3b6a00a9ea456b5609ec43f7\\core-1.0.0\\res\\values-pt-rBR\\values-pt-rBR.xml",
+ "from": {
+ "startLines": "2",
+ "startColumns": "4",
+ "startOffsets": "55",
+ "endColumns": "100",
+ "endOffsets": "151"
+ },
+ "to": {
+ "startLines": "30",
+ "startColumns": "4",
+ "startOffsets": "2929",
+ "endColumns": "100",
+ "endOffsets": "3025"
+ }
+ }
+ ]
+ },
+ {
+ "outputFile": "E:\\Note\\src\\app\\build\\intermediates\\res\\merged\\debug\\values-watch-v20_values-watch-v20.arsc.flat",
+ "map": [
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\88c548461109b0c917067cfea58751b3\\appcompat-1.0.0-alpha1\\res\\values-watch-v20\\values-watch-v20.xml",
+ "from": {
+ "startLines": "2,5,8",
+ "startColumns": "4,4,4",
+ "startOffsets": "55,214,385",
+ "endLines": "4,7,10",
+ "endColumns": "12,12,12",
+ "endOffsets": "209,380,553"
+ }
+ }
+ ]
+ },
+ {
+ "outputFile": "E:\\Note\\src\\app\\build\\intermediates\\res\\merged\\debug\\values-vi_values-vi.arsc.flat",
+ "map": [
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\88c548461109b0c917067cfea58751b3\\appcompat-1.0.0-alpha1\\res\\values-vi\\values-vi.xml",
+ "from": {
+ "startLines": "2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19,20,21,22,23,24,25,26,27,28,29",
+ "startColumns": "4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4",
+ "startOffsets": "105,219,327,436,520,623,742,819,896,987,1080,1176,1270,1371,1464,1559,1657,1748,1839,1923,2027,2136,2237,2342,2456,2561,2718,2817",
+ "endColumns": "113,107,108,83,102,118,76,76,90,92,95,93,100,92,94,97,90,90,83,103,108,100,104,113,104,156,98,83",
+ "endOffsets": "214,322,431,515,618,737,814,891,982,1075,1171,1265,1366,1459,1554,1652,1743,1834,1918,2022,2131,2232,2337,2451,2556,2713,2812,2896"
+ }
+ },
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\6d11613c3b6a00a9ea456b5609ec43f7\\core-1.0.0\\res\\values-vi\\values-vi.xml",
+ "from": {
+ "startLines": "2",
+ "startColumns": "4",
+ "startOffsets": "55",
+ "endColumns": "100",
+ "endOffsets": "151"
+ },
+ "to": {
+ "startLines": "30",
+ "startColumns": "4",
+ "startOffsets": "2901",
+ "endColumns": "100",
+ "endOffsets": "2997"
+ }
+ }
+ ]
+ },
+ {
+ "outputFile": "E:\\Note\\src\\app\\build\\intermediates\\res\\merged\\debug\\values-en-rIN_values-en-rIN.arsc.flat",
+ "map": [
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\6d11613c3b6a00a9ea456b5609ec43f7\\core-1.0.0\\res\\values-en-rIN\\values-en-rIN.xml",
+ "from": {
+ "startLines": "2",
+ "startColumns": "4",
+ "startOffsets": "55",
+ "endColumns": "100",
+ "endOffsets": "151"
+ },
+ "to": {
+ "startLines": "30",
+ "startColumns": "4",
+ "startOffsets": "2846",
+ "endColumns": "100",
+ "endOffsets": "2942"
+ }
+ },
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\88c548461109b0c917067cfea58751b3\\appcompat-1.0.0-alpha1\\res\\values-en-rIN\\values-en-rIN.xml",
+ "from": {
+ "startLines": "2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19,20,21,22,23,24,25,26,27,28,29",
+ "startColumns": "4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4",
+ "startOffsets": "105,209,309,417,501,601,716,793,869,960,1053,1149,1243,1344,1437,1532,1626,1717,1808,1890,1993,2097,2196,2301,2404,2508,2664,2764",
+ "endColumns": "103,99,107,83,99,114,76,75,90,92,95,93,100,92,94,93,90,90,81,102,103,98,104,102,103,155,99,81",
+ "endOffsets": "204,304,412,496,596,711,788,864,955,1048,1144,1238,1339,1432,1527,1621,1712,1803,1885,1988,2092,2191,2296,2399,2503,2659,2759,2841"
+ }
+ }
+ ]
+ },
+ {
+ "outputFile": "E:\\Note\\src\\app\\build\\intermediates\\res\\merged\\debug\\values-night-v8_values-night-v8.arsc.flat",
+ "map": [
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\88c548461109b0c917067cfea58751b3\\appcompat-1.0.0-alpha1\\res\\values-night-v8\\values-night-v8.xml",
+ "from": {
+ "startLines": "2,3,4,5,6,7,8",
+ "startColumns": "4,4,4,4,4,4,4",
+ "startOffsets": "55,125,209,293,389,491,593",
+ "endColumns": "69,83,83,95,101,101,93",
+ "endOffsets": "120,204,288,384,486,588,682"
+ }
+ }
+ ]
+ },
+ {
+ "outputFile": "E:\\Note\\src\\app\\build\\intermediates\\res\\merged\\debug\\values-v21_values-v21.arsc.flat",
+ "map": [
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\88c548461109b0c917067cfea58751b3\\appcompat-1.0.0-alpha1\\res\\values-v21\\values-v21.xml",
+ "from": {
+ "startLines": "2,3,4,5,6,7,8,9,10,11,12,13,14,15,17,19,20,21,22,24,26,27,28,29,30,32,34,36,38,40,42,43,48,50,52,53,54,56,58,59,60,61,62,63,107,110,154,157,160,162,164,166,169,171,174,175,176,179,180,181,182,183,184,187,188,190,192,194,196,200,202,203,204,205,207,211,213,215,216,217,218,219,221,222,223,233,234,235,247",
+ "startColumns": "4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4",
+ "startOffsets": "55,146,249,352,457,564,673,782,891,1000,1109,1216,1319,1438,1593,1748,1853,1974,2075,2222,2363,2466,2585,2692,2795,2950,3121,3270,3435,3592,3743,3862,4234,4383,4532,4644,4791,4944,5091,5166,5255,5342,5443,5546,8614,8799,11879,12076,12275,12398,12521,12634,12817,12948,13149,13238,13349,13582,13683,13778,13901,14030,14147,14324,14423,14558,14701,14836,14955,15156,15275,15368,15479,15535,15642,15837,15948,16081,16176,16267,16358,16475,16614,16685,16768,17448,17505,17563,18257",
+ "endLines": "2,3,4,5,6,7,8,9,10,11,12,13,14,16,18,19,20,21,23,25,26,27,28,29,31,33,35,37,39,41,42,47,49,51,52,53,55,57,58,59,60,61,62,106,109,153,156,159,161,163,165,168,170,173,174,175,178,179,180,181,182,183,186,187,189,191,193,195,199,201,202,203,204,206,210,212,214,215,216,217,218,220,221,222,232,233,234,246,258",
+ "endColumns": "90,102,102,104,106,108,108,108,108,108,106,102,118,12,12,104,120,100,12,12,102,118,106,102,12,12,12,12,12,12,118,12,12,12,111,146,12,12,74,88,86,100,102,12,12,12,12,12,12,12,12,12,12,12,88,110,12,100,94,122,128,116,12,98,12,12,12,12,12,12,92,110,55,12,12,12,12,94,90,90,116,12,70,82,12,56,57,12,12",
+ "endOffsets": "141,244,347,452,559,668,777,886,995,1104,1211,1314,1433,1588,1743,1848,1969,2070,2217,2358,2461,2580,2687,2790,2945,3116,3265,3430,3587,3738,3857,4229,4378,4527,4639,4786,4939,5086,5161,5250,5337,5438,5541,8609,8794,11874,12071,12270,12393,12516,12629,12812,12943,13144,13233,13344,13577,13678,13773,13896,14025,14142,14319,14418,14553,14696,14831,14950,15151,15270,15363,15474,15530,15637,15832,15943,16076,16171,16262,16353,16470,16609,16680,16763,17443,17500,17558,18252,18958"
+ },
+ "to": {
+ "startLines": "6,7,8,9,10,11,12,13,14,15,16,17,18,19,21,23,24,25,26,28,30,31,32,33,34,36,38,40,42,44,46,47,52,54,56,57,58,60,62,63,64,65,66,67,111,114,158,161,164,166,168,170,173,175,178,179,180,183,184,185,186,187,188,191,192,194,196,198,200,204,206,207,208,209,211,215,217,219,220,221,222,223,225,226,227,237,238,239,251",
+ "startColumns": "4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4",
+ "startOffsets": "354,445,548,651,756,863,972,1081,1190,1299,1408,1515,1618,1737,1892,2047,2152,2273,2374,2521,2662,2765,2884,2991,3094,3249,3420,3569,3734,3891,4042,4161,4533,4682,4831,4943,5090,5243,5390,5465,5554,5641,5742,5845,8913,9098,12178,12375,12574,12697,12820,12933,13116,13247,13448,13537,13648,13881,13982,14077,14200,14329,14446,14623,14722,14857,15000,15135,15254,15455,15574,15667,15778,15834,15941,16136,16247,16380,16475,16566,16657,16774,16913,16984,17067,17747,17804,17862,18556",
+ "endLines": "6,7,8,9,10,11,12,13,14,15,16,17,18,20,22,23,24,25,27,29,30,31,32,33,35,37,39,41,43,45,46,51,53,55,56,57,59,61,62,63,64,65,66,110,113,157,160,163,165,167,169,172,174,177,178,179,182,183,184,185,186,187,190,191,193,195,197,199,203,205,206,207,208,210,214,216,218,219,220,221,222,224,225,226,236,237,238,250,262",
+ "endColumns": "90,102,102,104,106,108,108,108,108,108,106,102,118,12,12,104,120,100,12,12,102,118,106,102,12,12,12,12,12,12,118,12,12,12,111,146,12,12,74,88,86,100,102,12,12,12,12,12,12,12,12,12,12,12,88,110,12,100,94,122,128,116,12,98,12,12,12,12,12,12,92,110,55,12,12,12,12,94,90,90,116,12,70,82,12,56,57,12,12",
+ "endOffsets": "440,543,646,751,858,967,1076,1185,1294,1403,1510,1613,1732,1887,2042,2147,2268,2369,2516,2657,2760,2879,2986,3089,3244,3415,3564,3729,3886,4037,4156,4528,4677,4826,4938,5085,5238,5385,5460,5549,5636,5737,5840,8908,9093,12173,12370,12569,12692,12815,12928,13111,13242,13443,13532,13643,13876,13977,14072,14195,14324,14441,14618,14717,14852,14995,15130,15249,15450,15569,15662,15773,15829,15936,16131,16242,16375,16470,16561,16652,16769,16908,16979,17062,17742,17799,17857,18551,19257"
+ }
+ },
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\6d11613c3b6a00a9ea456b5609ec43f7\\core-1.0.0\\res\\values-v21\\values-v21.xml",
+ "from": {
+ "startLines": "2,3,4,5,6,7,8,9,10,13",
+ "startColumns": "4,4,4,4,4,4,4,4,4,4",
+ "startOffsets": "55,159,223,290,354,470,596,722,850,1022",
+ "endLines": "2,3,4,5,6,7,8,9,12,17",
+ "endColumns": "103,63,66,63,115,125,125,127,12,12",
+ "endOffsets": "154,218,285,349,465,591,717,845,1017,1355"
+ },
+ "to": {
+ "startLines": "2,3,4,5,263,264,271,275,279,282",
+ "startColumns": "4,4,4,4,4,4,4,4,4,4",
+ "startOffsets": "55,159,223,290,19262,19378,19835,20129,20424,20596",
+ "endLines": "2,3,4,5,263,264,271,275,281,286",
+ "endColumns": "103,63,66,63,115,125,125,127,12,12",
+ "endOffsets": "154,218,285,349,19373,19499,19956,20252,20591,20929"
+ }
+ },
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\702974eead929cb167f132efe0eabb04\\media-1.0.0\\res\\values-v21\\values-v21.xml",
+ "from": {
+ "startLines": "2,5,8,11",
+ "startColumns": "4,4,4,4",
+ "startOffsets": "55,223,386,554",
+ "endLines": "4,7,10,13",
+ "endColumns": "12,12,12,12",
+ "endOffsets": "218,381,549,716"
+ },
+ "to": {
+ "startLines": "265,268,272,276",
+ "startColumns": "4,4,4,4",
+ "startOffsets": "19504,19672,19961,20257",
+ "endLines": "267,270,274,278",
+ "endColumns": "12,12,12,12",
+ "endOffsets": "19667,19830,20124,20419"
+ }
+ }
+ ]
+ },
+ {
+ "outputFile": "E:\\Note\\src\\app\\build\\intermediates\\res\\merged\\debug\\values-lv_values-lv.arsc.flat",
+ "map": [
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\6d11613c3b6a00a9ea456b5609ec43f7\\core-1.0.0\\res\\values-lv\\values-lv.xml",
+ "from": {
+ "startLines": "2",
+ "startColumns": "4",
+ "startOffsets": "55",
+ "endColumns": "100",
+ "endOffsets": "151"
+ },
+ "to": {
+ "startLines": "30",
+ "startColumns": "4",
+ "startOffsets": "3076",
+ "endColumns": "100",
+ "endOffsets": "3172"
+ }
+ },
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\88c548461109b0c917067cfea58751b3\\appcompat-1.0.0-alpha1\\res\\values-lv\\values-lv.xml",
+ "from": {
+ "startLines": "2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19,20,21,22,23,24,25,26,27,28,29",
+ "startColumns": "4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4",
+ "startOffsets": "105,225,333,442,528,632,754,836,918,1028,1136,1243,1352,1464,1567,1679,1786,1891,1991,2076,2185,2297,2396,2507,2616,2721,2895,2994",
+ "endColumns": "119,107,108,85,103,121,81,81,109,107,106,108,111,102,111,106,104,99,84,108,111,98,110,108,104,173,98,81",
+ "endOffsets": "220,328,437,523,627,749,831,913,1023,1131,1238,1347,1459,1562,1674,1781,1886,1986,2071,2180,2292,2391,2502,2611,2716,2890,2989,3071"
+ }
+ }
+ ]
+ },
+ {
+ "outputFile": "E:\\Note\\src\\app\\build\\intermediates\\res\\merged\\debug\\values-v23_values-v23.arsc.flat",
+ "map": [
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\88c548461109b0c917067cfea58751b3\\appcompat-1.0.0-alpha1\\res\\values-v23\\values-v23.xml",
+ "from": {
+ "startLines": "2,3,4,5,6,19,32,33,34,35,36",
+ "startColumns": "4,4,4,4,4,4,4,4,4,4,4",
+ "startOffsets": "55,190,325,400,487,1277,2079,2206,2311,2426,2533",
+ "endLines": "2,3,4,5,18,31,32,33,34,35,36",
+ "endColumns": "134,134,74,86,12,12,126,104,114,106,112",
+ "endOffsets": "185,320,395,482,1272,2074,2201,2306,2421,2528,2641"
+ }
+ }
+ ]
+ },
+ {
+ "outputFile": "E:\\Note\\src\\app\\build\\intermediates\\res\\merged\\debug\\values-is_values-is.arsc.flat",
+ "map": [
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\6d11613c3b6a00a9ea456b5609ec43f7\\core-1.0.0\\res\\values-is\\values-is.xml",
+ "from": {
+ "startLines": "2",
+ "startColumns": "4",
+ "startOffsets": "55",
+ "endColumns": "100",
+ "endOffsets": "151"
+ },
+ "to": {
+ "startLines": "30",
+ "startColumns": "4",
+ "startOffsets": "2865",
+ "endColumns": "100",
+ "endOffsets": "2961"
+ }
+ },
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\88c548461109b0c917067cfea58751b3\\appcompat-1.0.0-alpha1\\res\\values-is\\values-is.xml",
+ "from": {
+ "startLines": "2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19,20,21,22,23,24,25,26,27,28,29",
+ "startColumns": "4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4",
+ "startOffsets": "105,205,302,414,499,600,714,794,874,965,1058,1154,1248,1355,1448,1543,1638,1729,1823,1904,2014,2122,2220,2329,2428,2531,2686,2784",
+ "endColumns": "99,96,111,84,100,113,79,79,90,92,95,93,106,92,94,94,90,93,80,109,107,97,108,98,102,154,97,80",
+ "endOffsets": "200,297,409,494,595,709,789,869,960,1053,1149,1243,1350,1443,1538,1633,1724,1818,1899,2009,2117,2215,2324,2423,2526,2681,2779,2860"
+ }
+ }
+ ]
+ },
+ {
+ "outputFile": "E:\\Note\\src\\app\\build\\intermediates\\res\\merged\\debug\\values-en-rCA_values-en-rCA.arsc.flat",
+ "map": [
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\88c548461109b0c917067cfea58751b3\\appcompat-1.0.0-alpha1\\res\\values-en-rCA\\values-en-rCA.xml",
+ "from": {
+ "startLines": "2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19,20,21,22,23,24,25,26,27,28,29",
+ "startColumns": "4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4",
+ "startOffsets": "105,209,309,417,501,601,716,793,869,960,1053,1149,1243,1344,1437,1532,1626,1717,1808,1890,1993,2097,2196,2301,2404,2508,2664,2764",
+ "endColumns": "103,99,107,83,99,114,76,75,90,92,95,93,100,92,94,93,90,90,81,102,103,98,104,102,103,155,99,81",
+ "endOffsets": "204,304,412,496,596,711,788,864,955,1048,1144,1238,1339,1432,1527,1621,1712,1803,1885,1988,2092,2191,2296,2399,2503,2659,2759,2841"
+ }
+ },
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\6d11613c3b6a00a9ea456b5609ec43f7\\core-1.0.0\\res\\values-en-rCA\\values-en-rCA.xml",
+ "from": {
+ "startLines": "2",
+ "startColumns": "4",
+ "startOffsets": "55",
+ "endColumns": "100",
+ "endOffsets": "151"
+ },
+ "to": {
+ "startLines": "30",
+ "startColumns": "4",
+ "startOffsets": "2846",
+ "endColumns": "100",
+ "endOffsets": "2942"
+ }
+ }
+ ]
+ },
+ {
+ "outputFile": "E:\\Note\\src\\app\\build\\intermediates\\res\\merged\\debug\\values-v25_values-v25.arsc.flat",
+ "map": [
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\88c548461109b0c917067cfea58751b3\\appcompat-1.0.0-alpha1\\res\\values-v25\\values-v25.xml",
+ "from": {
+ "startLines": "2,3,4,6",
+ "startColumns": "4,4,4,4",
+ "startOffsets": "55,126,209,308",
+ "endLines": "2,3,5,7",
+ "endColumns": "70,82,12,12",
+ "endOffsets": "121,204,303,414"
+ }
+ }
+ ]
+ },
+ {
+ "outputFile": "E:\\Note\\src\\app\\build\\intermediates\\res\\merged\\debug\\values-lo_values-lo.arsc.flat",
+ "map": [
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\6d11613c3b6a00a9ea456b5609ec43f7\\core-1.0.0\\res\\values-lo\\values-lo.xml",
+ "from": {
+ "startLines": "2",
+ "startColumns": "4",
+ "startOffsets": "55",
+ "endColumns": "100",
+ "endOffsets": "151"
+ },
+ "to": {
+ "startLines": "30",
+ "startColumns": "4",
+ "startOffsets": "2836",
+ "endColumns": "100",
+ "endOffsets": "2932"
+ }
+ },
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\88c548461109b0c917067cfea58751b3\\appcompat-1.0.0-alpha1\\res\\values-lo\\values-lo.xml",
+ "from": {
+ "startLines": "2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19,20,21,22,23,24,25,26,27,28,29",
+ "startColumns": "4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4",
+ "startOffsets": "105,208,305,412,497,602,714,791,869,960,1053,1149,1243,1344,1437,1532,1626,1717,1808,1888,1995,2092,2190,2295,2398,2502,2659,2755",
+ "endColumns": "102,96,106,84,104,111,76,77,90,92,95,93,100,92,94,93,90,90,79,106,96,97,104,102,103,156,95,80",
+ "endOffsets": "203,300,407,492,597,709,786,864,955,1048,1144,1238,1339,1432,1527,1621,1712,1803,1883,1990,2087,2185,2290,2393,2497,2654,2750,2831"
+ }
+ }
+ ]
+ },
+ {
+ "outputFile": "E:\\Note\\src\\app\\build\\intermediates\\res\\merged\\debug\\values-uz_values-uz.arsc.flat",
+ "map": [
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\6d11613c3b6a00a9ea456b5609ec43f7\\core-1.0.0\\res\\values-uz\\values-uz.xml",
+ "from": {
+ "startLines": "2",
+ "startColumns": "4",
+ "startOffsets": "55",
+ "endColumns": "100",
+ "endOffsets": "151"
+ },
+ "to": {
+ "startLines": "30",
+ "startColumns": "4",
+ "startOffsets": "2889",
+ "endColumns": "100",
+ "endOffsets": "2985"
+ }
+ },
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\88c548461109b0c917067cfea58751b3\\appcompat-1.0.0-alpha1\\res\\values-uz\\values-uz.xml",
+ "from": {
+ "startLines": "2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19,20,21,22,23,24,25,26,27,28,29",
+ "startColumns": "4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4",
+ "startOffsets": "105,210,314,428,514,614,730,810,889,980,1073,1169,1263,1358,1451,1546,1641,1732,1824,1908,2017,2124,2225,2333,2438,2545,2706,2805",
+ "endColumns": "104,103,113,85,99,115,79,78,90,92,95,93,94,92,94,94,90,91,83,108,106,100,107,104,106,160,98,83",
+ "endOffsets": "205,309,423,509,609,725,805,884,975,1068,1164,1258,1353,1446,1541,1636,1727,1819,1903,2012,2119,2220,2328,2433,2540,2701,2800,2884"
+ }
+ }
+ ]
+ },
+ {
+ "outputFile": "E:\\Note\\src\\app\\build\\intermediates\\res\\merged\\debug\\values-zh-rTW_values-zh-rTW.arsc.flat",
+ "map": [
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\6d11613c3b6a00a9ea456b5609ec43f7\\core-1.0.0\\res\\values-zh-rTW\\values-zh-rTW.xml",
+ "from": {
+ "startLines": "2",
+ "startColumns": "4",
+ "startOffsets": "55",
+ "endColumns": "100",
+ "endOffsets": "151"
+ },
+ "to": {
+ "startLines": "34",
+ "startColumns": "4",
+ "startOffsets": "2863",
+ "endColumns": "100",
+ "endOffsets": "2959"
+ }
+ },
+ {
+ "source": "E:\\Note\\src\\app\\src\\main\\res\\values-zh-rTW\\arrays.xml",
+ "from": {
+ "startLines": "18",
+ "startColumns": "4",
+ "startOffsets": "730",
+ "endLines": "21",
+ "endColumns": "19",
+ "endOffsets": "838"
+ },
+ "to": {
+ "startLines": "2",
+ "startColumns": "4",
+ "startOffsets": "105",
+ "endLines": "5",
+ "endColumns": "19",
+ "endOffsets": "210"
+ }
+ },
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\88c548461109b0c917067cfea58751b3\\appcompat-1.0.0-alpha1\\res\\values-zh-rTW\\values-zh-rTW.xml",
+ "from": {
+ "startLines": "2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19,20,21,22,23,24,25,26,27,28,29",
+ "startColumns": "4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4",
+ "startOffsets": "105,200,293,393,475,572,680,756,832,924,1018,1116,1212,1308,1402,1498,1590,1682,1774,1852,1948,2044,2139,2236,2331,2431,2581,2675",
+ "endColumns": "94,92,99,81,96,107,75,75,91,93,97,95,95,93,95,91,91,91,77,95,95,94,96,94,99,149,93,77",
+ "endOffsets": "195,288,388,470,567,675,751,827,919,1013,1111,1207,1303,1397,1493,1585,1677,1769,1847,1943,2039,2134,2231,2326,2426,2576,2670,2748"
+ },
+ "to": {
+ "startLines": "6,7,8,9,10,11,12,13,14,15,16,17,18,19,20,21,22,23,24,25,26,27,28,29,30,31,32,33",
+ "startColumns": "4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4",
+ "startOffsets": "215,310,403,503,585,682,790,866,942,1034,1128,1226,1322,1418,1512,1608,1700,1792,1884,1962,2058,2154,2249,2346,2441,2541,2691,2785",
+ "endColumns": "94,92,99,81,96,107,75,75,91,93,97,95,95,93,95,91,91,91,77,95,95,94,96,94,99,149,93,77",
+ "endOffsets": "305,398,498,580,677,785,861,937,1029,1123,1221,1317,1413,1507,1603,1695,1787,1879,1957,2053,2149,2244,2341,2436,2536,2686,2780,2858"
+ }
+ }
+ ]
+ },
+ {
+ "outputFile": "E:\\Note\\src\\app\\build\\intermediates\\res\\merged\\debug\\values-th_values-th.arsc.flat",
+ "map": [
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\88c548461109b0c917067cfea58751b3\\appcompat-1.0.0-alpha1\\res\\values-th\\values-th.xml",
+ "from": {
+ "startLines": "2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19,20,21,22,23,24,25,26,27,28,29",
+ "startColumns": "4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4",
+ "startOffsets": "105,210,308,416,505,607,717,794,872,963,1056,1152,1246,1347,1440,1535,1629,1720,1811,1892,2000,2104,2202,2310,2415,2516,2669,2764",
+ "endColumns": "104,97,107,88,101,109,76,77,90,92,95,93,100,92,94,93,90,90,80,107,103,97,107,104,100,152,94,80",
+ "endOffsets": "205,303,411,500,602,712,789,867,958,1051,1147,1241,1342,1435,1530,1624,1715,1806,1887,1995,2099,2197,2305,2410,2511,2664,2759,2840"
+ }
+ },
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\6d11613c3b6a00a9ea456b5609ec43f7\\core-1.0.0\\res\\values-th\\values-th.xml",
+ "from": {
+ "startLines": "2",
+ "startColumns": "4",
+ "startOffsets": "55",
+ "endColumns": "100",
+ "endOffsets": "151"
+ },
+ "to": {
+ "startLines": "30",
+ "startColumns": "4",
+ "startOffsets": "2845",
+ "endColumns": "100",
+ "endOffsets": "2941"
+ }
+ }
+ ]
+ },
+ {
+ "outputFile": "E:\\Note\\src\\app\\build\\intermediates\\res\\merged\\debug\\values-ja_values-ja.arsc.flat",
+ "map": [
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\88c548461109b0c917067cfea58751b3\\appcompat-1.0.0-alpha1\\res\\values-ja\\values-ja.xml",
+ "from": {
+ "startLines": "2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19,20,21,22,23,24,25,26,27,28,29",
+ "startColumns": "4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4",
+ "startOffsets": "105,202,295,400,482,580,688,765,841,932,1025,1121,1215,1316,1409,1504,1598,1689,1780,1858,1960,2059,2154,2257,2352,2448,2596,2693",
+ "endColumns": "96,92,104,81,97,107,76,75,90,92,95,93,100,92,94,93,90,90,77,101,98,94,102,94,95,147,96,77",
+ "endOffsets": "197,290,395,477,575,683,760,836,927,1020,1116,1210,1311,1404,1499,1593,1684,1775,1853,1955,2054,2149,2252,2347,2443,2591,2688,2766"
+ }
+ },
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\6d11613c3b6a00a9ea456b5609ec43f7\\core-1.0.0\\res\\values-ja\\values-ja.xml",
+ "from": {
+ "startLines": "2",
+ "startColumns": "4",
+ "startOffsets": "55",
+ "endColumns": "100",
+ "endOffsets": "151"
+ },
+ "to": {
+ "startLines": "30",
+ "startColumns": "4",
+ "startOffsets": "2771",
+ "endColumns": "100",
+ "endOffsets": "2867"
+ }
+ }
+ ]
+ },
+ {
+ "outputFile": "E:\\Note\\src\\app\\build\\intermediates\\res\\merged\\debug\\values-ru_values-ru.arsc.flat",
+ "map": [
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\88c548461109b0c917067cfea58751b3\\appcompat-1.0.0-alpha1\\res\\values-ru\\values-ru.xml",
+ "from": {
+ "startLines": "2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19,20,21,22,23,24,25,26,27,28,29",
+ "startColumns": "4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4",
+ "startOffsets": "105,220,322,434,520,625,745,824,902,994,1088,1184,1277,1373,1467,1563,1658,1750,1842,1922,2028,2136,2234,2343,2449,2557,2732,2832",
+ "endColumns": "114,101,111,85,104,119,78,77,91,93,95,92,95,93,95,94,91,91,79,105,107,97,108,105,107,174,99,80",
+ "endOffsets": "215,317,429,515,620,740,819,897,989,1083,1179,1272,1368,1462,1558,1653,1745,1837,1917,2023,2131,2229,2338,2444,2552,2727,2827,2908"
+ }
+ },
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\6d11613c3b6a00a9ea456b5609ec43f7\\core-1.0.0\\res\\values-ru\\values-ru.xml",
+ "from": {
+ "startLines": "2",
+ "startColumns": "4",
+ "startOffsets": "55",
+ "endColumns": "100",
+ "endOffsets": "151"
+ },
+ "to": {
+ "startLines": "30",
+ "startColumns": "4",
+ "startOffsets": "2913",
+ "endColumns": "100",
+ "endOffsets": "3009"
+ }
+ }
+ ]
+ },
+ {
+ "outputFile": "E:\\Note\\src\\app\\build\\intermediates\\res\\merged\\debug\\values-ko_values-ko.arsc.flat",
+ "map": [
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\6d11613c3b6a00a9ea456b5609ec43f7\\core-1.0.0\\res\\values-ko\\values-ko.xml",
+ "from": {
+ "startLines": "2",
+ "startColumns": "4",
+ "startOffsets": "55",
+ "endColumns": "100",
+ "endOffsets": "151"
+ },
+ "to": {
+ "startLines": "30",
+ "startColumns": "4",
+ "startOffsets": "2756",
+ "endColumns": "100",
+ "endOffsets": "2852"
+ }
+ },
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\88c548461109b0c917067cfea58751b3\\appcompat-1.0.0-alpha1\\res\\values-ko\\values-ko.xml",
+ "from": {
+ "startLines": "2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19,20,21,22,23,24,25,26,27,28,29",
+ "startColumns": "4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4",
+ "startOffsets": "105,200,294,396,478,576,682,761,837,928,1021,1113,1204,1305,1398,1493,1587,1678,1769,1849,1947,2042,2137,2237,2333,2432,2584,2678",
+ "endColumns": "94,93,101,81,97,105,78,75,90,92,91,90,100,92,94,93,90,90,79,97,94,94,99,95,98,151,93,77",
+ "endOffsets": "195,289,391,473,571,677,756,832,923,1016,1108,1199,1300,1393,1488,1582,1673,1764,1844,1942,2037,2132,2232,2328,2427,2579,2673,2751"
+ }
+ }
+ ]
+ },
+ {
+ "outputFile": "E:\\Note\\src\\app\\build\\intermediates\\res\\merged\\debug\\values-in_values-in.arsc.flat",
+ "map": [
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\6d11613c3b6a00a9ea456b5609ec43f7\\core-1.0.0\\res\\values-in\\values-in.xml",
+ "from": {
+ "startLines": "2",
+ "startColumns": "4",
+ "startOffsets": "55",
+ "endColumns": "100",
+ "endOffsets": "151"
+ },
+ "to": {
+ "startLines": "30",
+ "startColumns": "4",
+ "startOffsets": "2887",
+ "endColumns": "100",
+ "endOffsets": "2983"
+ }
+ },
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\88c548461109b0c917067cfea58751b3\\appcompat-1.0.0-alpha1\\res\\values-in\\values-in.xml",
+ "from": {
+ "startLines": "2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19,20,21,22,23,24,25,26,27,28,29",
+ "startColumns": "4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4",
+ "startOffsets": "105,215,317,422,509,613,729,811,890,981,1074,1170,1264,1365,1458,1553,1647,1738,1829,1915,2018,2127,2228,2332,2440,2548,2704,2803",
+ "endColumns": "109,101,104,86,103,115,81,78,90,92,95,93,100,92,94,93,90,90,85,102,108,100,103,107,107,155,98,83",
+ "endOffsets": "210,312,417,504,608,724,806,885,976,1069,1165,1259,1360,1453,1548,1642,1733,1824,1910,2013,2122,2223,2327,2435,2543,2699,2798,2882"
+ }
+ }
+ ]
+ },
+ {
+ "outputFile": "E:\\Note\\src\\app\\build\\intermediates\\res\\merged\\debug\\values-mk_values-mk.arsc.flat",
+ "map": [
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\6d11613c3b6a00a9ea456b5609ec43f7\\core-1.0.0\\res\\values-mk\\values-mk.xml",
+ "from": {
+ "startLines": "2",
+ "startColumns": "4",
+ "startOffsets": "55",
+ "endColumns": "100",
+ "endOffsets": "151"
+ },
+ "to": {
+ "startLines": "30",
+ "startColumns": "4",
+ "startOffsets": "2945",
+ "endColumns": "100",
+ "endOffsets": "3041"
+ }
+ },
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\88c548461109b0c917067cfea58751b3\\appcompat-1.0.0-alpha1\\res\\values-mk\\values-mk.xml",
+ "from": {
+ "startLines": "2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19,20,21,22,23,24,25,26,27,28,29",
+ "startColumns": "4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4",
+ "startOffsets": "105,213,317,425,511,616,735,818,900,997,1096,1193,1293,1400,1499,1600,1696,1793,1884,1971,2077,2184,2285,2392,2503,2607,2763,2861",
+ "endColumns": "107,103,107,85,104,118,82,81,96,98,96,99,106,98,100,95,96,90,86,105,106,100,106,110,103,155,97,83",
+ "endOffsets": "208,312,420,506,611,730,813,895,992,1091,1188,1288,1395,1494,1595,1691,1788,1879,1966,2072,2179,2280,2387,2498,2602,2758,2856,2940"
+ }
+ }
+ ]
+ },
+ {
+ "outputFile": "E:\\Note\\src\\app\\build\\intermediates\\res\\merged\\debug\\values-es-rUS_values-es-rUS.arsc.flat",
+ "map": [
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\88c548461109b0c917067cfea58751b3\\appcompat-1.0.0-alpha1\\res\\values-es-rUS\\values-es-rUS.xml",
+ "from": {
+ "startLines": "2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19,20,21,22,23,24,25,26,27,28,29",
+ "startColumns": "4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4",
+ "startOffsets": "105,225,334,442,527,628,751,836,918,1009,1102,1198,1292,1392,1485,1584,1680,1771,1862,1944,2056,2156,2257,2365,2472,2579,2738,2838",
+ "endColumns": "119,108,107,84,100,122,84,81,90,92,95,93,99,92,98,95,90,90,81,111,99,100,107,106,106,158,99,81",
+ "endOffsets": "220,329,437,522,623,746,831,913,1004,1097,1193,1287,1387,1480,1579,1675,1766,1857,1939,2051,2151,2252,2360,2467,2574,2733,2833,2915"
+ }
+ },
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\6d11613c3b6a00a9ea456b5609ec43f7\\core-1.0.0\\res\\values-es-rUS\\values-es-rUS.xml",
+ "from": {
+ "startLines": "2",
+ "startColumns": "4",
+ "startOffsets": "55",
+ "endColumns": "100",
+ "endOffsets": "151"
+ },
+ "to": {
+ "startLines": "30",
+ "startColumns": "4",
+ "startOffsets": "2920",
+ "endColumns": "100",
+ "endOffsets": "3016"
+ }
+ }
+ ]
+ },
+ {
+ "outputFile": "E:\\Note\\src\\app\\build\\intermediates\\res\\merged\\debug\\values-tl_values-tl.arsc.flat",
+ "map": [
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\88c548461109b0c917067cfea58751b3\\appcompat-1.0.0-alpha1\\res\\values-tl\\values-tl.xml",
+ "from": {
+ "startLines": "2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19,20,21,22,23,24,25,26,27,28,29",
+ "startColumns": "4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4",
+ "startOffsets": "105,224,332,449,537,643,764,843,921,1012,1105,1201,1295,1396,1489,1584,1678,1769,1860,1944,2053,2164,2265,2375,2492,2600,2763,2865",
+ "endColumns": "118,107,116,87,105,120,78,77,90,92,95,93,100,92,94,93,90,90,83,108,110,100,109,116,107,162,101,83",
+ "endOffsets": "219,327,444,532,638,759,838,916,1007,1100,1196,1290,1391,1484,1579,1673,1764,1855,1939,2048,2159,2260,2370,2487,2595,2758,2860,2944"
+ }
+ },
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\6d11613c3b6a00a9ea456b5609ec43f7\\core-1.0.0\\res\\values-tl\\values-tl.xml",
+ "from": {
+ "startLines": "2",
+ "startColumns": "4",
+ "startOffsets": "55",
+ "endColumns": "100",
+ "endOffsets": "151"
+ },
+ "to": {
+ "startLines": "30",
+ "startColumns": "4",
+ "startOffsets": "2949",
+ "endColumns": "100",
+ "endOffsets": "3045"
+ }
+ }
+ ]
+ },
+ {
+ "outputFile": "E:\\Note\\src\\app\\build\\intermediates\\res\\merged\\debug\\values-sl_values-sl.arsc.flat",
+ "map": [
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\88c548461109b0c917067cfea58751b3\\appcompat-1.0.0-alpha1\\res\\values-sl\\values-sl.xml",
+ "from": {
+ "startLines": "2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19,20,21,22,23,24,25,26,27,28,29",
+ "startColumns": "4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4",
+ "startOffsets": "105,212,319,427,514,617,736,821,905,997,1091,1187,1281,1377,1471,1567,1667,1759,1851,1935,2043,2152,2252,2365,2472,2576,2756,2853",
+ "endColumns": "106,106,107,86,102,118,84,83,91,93,95,93,95,93,95,99,91,91,83,107,108,99,112,106,103,179,96,82",
+ "endOffsets": "207,314,422,509,612,731,816,900,992,1086,1182,1276,1372,1466,1562,1662,1754,1846,1930,2038,2147,2247,2360,2467,2571,2751,2848,2931"
+ }
+ },
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\6d11613c3b6a00a9ea456b5609ec43f7\\core-1.0.0\\res\\values-sl\\values-sl.xml",
+ "from": {
+ "startLines": "2",
+ "startColumns": "4",
+ "startOffsets": "55",
+ "endColumns": "100",
+ "endOffsets": "151"
+ },
+ "to": {
+ "startLines": "30",
+ "startColumns": "4",
+ "startOffsets": "2936",
+ "endColumns": "100",
+ "endOffsets": "3032"
+ }
+ }
+ ]
+ },
+ {
+ "outputFile": "E:\\Note\\src\\app\\build\\intermediates\\res\\merged\\debug\\values-ka_values-ka.arsc.flat",
+ "map": [
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\6d11613c3b6a00a9ea456b5609ec43f7\\core-1.0.0\\res\\values-ka\\values-ka.xml",
+ "from": {
+ "startLines": "2",
+ "startColumns": "4",
+ "startOffsets": "55",
+ "endColumns": "100",
+ "endOffsets": "151"
+ },
+ "to": {
+ "startLines": "30",
+ "startColumns": "4",
+ "startOffsets": "2899",
+ "endColumns": "100",
+ "endOffsets": "2995"
+ }
+ },
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\88c548461109b0c917067cfea58751b3\\appcompat-1.0.0-alpha1\\res\\values-ka\\values-ka.xml",
+ "from": {
+ "startLines": "2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19,20,21,22,23,24,25,26,27,28,29",
+ "startColumns": "4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4",
+ "startOffsets": "105,214,318,429,517,622,735,819,901,992,1085,1180,1276,1377,1470,1565,1659,1750,1841,1924,2037,2144,2242,2355,2459,2563,2720,2818",
+ "endColumns": "108,103,110,87,104,112,83,81,90,92,94,95,100,92,94,93,90,90,82,112,106,97,112,103,103,156,97,80",
+ "endOffsets": "209,313,424,512,617,730,814,896,987,1080,1175,1271,1372,1465,1560,1654,1745,1836,1919,2032,2139,2237,2350,2454,2558,2715,2813,2894"
+ }
+ }
+ ]
+ },
+ {
+ "outputFile": "E:\\Note\\src\\app\\build\\intermediates\\res\\merged\\debug\\values-fr_values-fr.arsc.flat",
+ "map": [
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\88c548461109b0c917067cfea58751b3\\appcompat-1.0.0-alpha1\\res\\values-fr\\values-fr.xml",
+ "from": {
+ "startLines": "2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19,20,21,22,23,24,25,26,27,28,29",
+ "startColumns": "4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4",
+ "startOffsets": "105,216,331,442,524,630,760,843,923,1014,1107,1206,1301,1402,1495,1588,1683,1774,1865,1951,2061,2173,2276,2387,2494,2601,2760,2859",
+ "endColumns": "110,114,110,81,105,129,82,79,90,92,98,94,100,92,92,94,90,90,85,109,111,102,110,106,106,158,98,85",
+ "endOffsets": "211,326,437,519,625,755,838,918,1009,1102,1201,1296,1397,1490,1583,1678,1769,1860,1946,2056,2168,2271,2382,2489,2596,2755,2854,2940"
+ }
+ },
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\6d11613c3b6a00a9ea456b5609ec43f7\\core-1.0.0\\res\\values-fr\\values-fr.xml",
+ "from": {
+ "startLines": "2",
+ "startColumns": "4",
+ "startOffsets": "55",
+ "endColumns": "100",
+ "endOffsets": "151"
+ },
+ "to": {
+ "startLines": "30",
+ "startColumns": "4",
+ "startOffsets": "2945",
+ "endColumns": "100",
+ "endOffsets": "3041"
+ }
+ }
+ ]
+ },
+ {
+ "outputFile": "E:\\Note\\src\\app\\build\\intermediates\\res\\merged\\debug\\values-v16_values-v16.arsc.flat",
+ "map": [
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\88c548461109b0c917067cfea58751b3\\appcompat-1.0.0-alpha1\\res\\values-v16\\values-v16.xml",
+ "from": {
+ "startLines": "2",
+ "startColumns": "4",
+ "startOffsets": "55",
+ "endLines": "5",
+ "endColumns": "12",
+ "endOffsets": "223"
+ },
+ "to": {
+ "startLines": "3",
+ "startColumns": "4",
+ "startOffsets": "121",
+ "endLines": "6",
+ "endColumns": "12",
+ "endOffsets": "289"
+ }
+ },
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\6d11613c3b6a00a9ea456b5609ec43f7\\core-1.0.0\\res\\values-v16\\values-v16.xml",
+ "from": {
+ "startLines": "2",
+ "startColumns": "4",
+ "startOffsets": "55",
+ "endColumns": "65",
+ "endOffsets": "116"
+ }
+ }
+ ]
+ },
+ {
+ "outputFile": "E:\\Note\\src\\app\\build\\intermediates\\res\\merged\\debug\\values-hr_values-hr.arsc.flat",
+ "map": [
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\6d11613c3b6a00a9ea456b5609ec43f7\\core-1.0.0\\res\\values-hr\\values-hr.xml",
+ "from": {
+ "startLines": "2",
+ "startColumns": "4",
+ "startOffsets": "55",
+ "endColumns": "100",
+ "endOffsets": "151"
+ },
+ "to": {
+ "startLines": "30",
+ "startColumns": "4",
+ "startOffsets": "2926",
+ "endColumns": "100",
+ "endOffsets": "3022"
+ }
+ },
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\88c548461109b0c917067cfea58751b3\\appcompat-1.0.0-alpha1\\res\\values-hr\\values-hr.xml",
+ "from": {
+ "startLines": "2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19,20,21,22,23,24,25,26,27,28,29",
+ "startColumns": "4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4",
+ "startOffsets": "105,210,307,417,503,607,726,810,893,984,1077,1173,1267,1368,1461,1556,1655,1746,1837,1923,2027,2140,2246,2351,2464,2571,2740,2837",
+ "endColumns": "104,96,109,85,103,118,83,82,90,92,95,93,100,92,94,98,90,90,85,103,112,105,104,112,106,168,96,88",
+ "endOffsets": "205,302,412,498,602,721,805,888,979,1072,1168,1262,1363,1456,1551,1650,1741,1832,1918,2022,2135,2241,2346,2459,2566,2735,2832,2921"
+ }
+ }
+ ]
+ },
+ {
+ "outputFile": "E:\\Note\\src\\app\\build\\intermediates\\res\\merged\\debug\\values-ldltr-v21_values-ldltr-v21.arsc.flat",
+ "map": [
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\88c548461109b0c917067cfea58751b3\\appcompat-1.0.0-alpha1\\res\\values-ldltr-v21\\values-ldltr-v21.xml",
+ "from": {
+ "startLines": "2",
+ "startColumns": "4",
+ "startOffsets": "55",
+ "endColumns": "112",
+ "endOffsets": "163"
+ }
+ }
+ ]
+ },
+ {
+ "outputFile": "E:\\Note\\src\\app\\build\\intermediates\\res\\merged\\debug\\values-ms_values-ms.arsc.flat",
+ "map": [
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\6d11613c3b6a00a9ea456b5609ec43f7\\core-1.0.0\\res\\values-ms\\values-ms.xml",
+ "from": {
+ "startLines": "2",
+ "startColumns": "4",
+ "startOffsets": "55",
+ "endColumns": "100",
+ "endOffsets": "151"
+ },
+ "to": {
+ "startLines": "30",
+ "startColumns": "4",
+ "startOffsets": "2881",
+ "endColumns": "100",
+ "endOffsets": "2977"
+ }
+ },
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\88c548461109b0c917067cfea58751b3\\appcompat-1.0.0-alpha1\\res\\values-ms\\values-ms.xml",
+ "from": {
+ "startLines": "2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19,20,21,22,23,24,25,26,27,28,29",
+ "startColumns": "4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4",
+ "startOffsets": "105,216,321,429,516,620,731,809,888,979,1072,1167,1261,1360,1453,1548,1642,1733,1824,1904,2016,2125,2222,2331,2434,2541,2700,2801",
+ "endColumns": "110,104,107,86,103,110,77,78,90,92,94,93,98,92,94,93,90,90,79,111,108,96,108,102,106,158,100,79",
+ "endOffsets": "211,316,424,511,615,726,804,883,974,1067,1162,1256,1355,1448,1543,1637,1728,1819,1899,2011,2120,2217,2326,2429,2536,2695,2796,2876"
+ }
+ }
+ ]
+ },
+ {
+ "outputFile": "E:\\Note\\src\\app\\build\\intermediates\\res\\merged\\debug\\values-sq_values-sq.arsc.flat",
+ "map": [
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\88c548461109b0c917067cfea58751b3\\appcompat-1.0.0-alpha1\\res\\values-sq\\values-sq.xml",
+ "from": {
+ "startLines": "2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19,20,21,22,23,24,25,26,27,28,29",
+ "startColumns": "4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4",
+ "startOffsets": "105,219,319,431,518,628,751,832,911,1002,1095,1191,1285,1387,1480,1575,1672,1763,1856,1939,2045,2150,2248,2354,2457,2573,2727,2826",
+ "endColumns": "113,99,111,86,109,122,80,78,90,92,95,93,101,92,94,96,90,92,82,105,104,97,105,102,115,153,98,80",
+ "endOffsets": "214,314,426,513,623,746,827,906,997,1090,1186,1280,1382,1475,1570,1667,1758,1851,1934,2040,2145,2243,2349,2452,2568,2722,2821,2902"
+ }
+ },
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\6d11613c3b6a00a9ea456b5609ec43f7\\core-1.0.0\\res\\values-sq\\values-sq.xml",
+ "from": {
+ "startLines": "2",
+ "startColumns": "4",
+ "startOffsets": "55",
+ "endColumns": "100",
+ "endOffsets": "151"
+ },
+ "to": {
+ "startLines": "30",
+ "startColumns": "4",
+ "startOffsets": "2907",
+ "endColumns": "100",
+ "endOffsets": "3003"
+ }
+ }
+ ]
+ },
+ {
+ "outputFile": "E:\\Note\\src\\app\\build\\intermediates\\res\\merged\\debug\\values-fa_values-fa.arsc.flat",
+ "map": [
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\6d11613c3b6a00a9ea456b5609ec43f7\\core-1.0.0\\res\\values-fa\\values-fa.xml",
+ "from": {
+ "startLines": "2",
+ "startColumns": "4",
+ "startOffsets": "55",
+ "endColumns": "100",
+ "endOffsets": "151"
+ },
+ "to": {
+ "startLines": "30",
+ "startColumns": "4",
+ "startOffsets": "2903",
+ "endColumns": "100",
+ "endOffsets": "2999"
+ }
+ },
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\88c548461109b0c917067cfea58751b3\\appcompat-1.0.0-alpha1\\res\\values-fa\\values-fa.xml",
+ "from": {
+ "startLines": "2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19,20,21,22,23,24,25,26,27,28,29",
+ "startColumns": "4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4",
+ "startOffsets": "105,215,318,429,513,616,731,810,888,981,1076,1172,1266,1369,1464,1561,1660,1753,1843,1924,2036,2139,2237,2347,2451,2560,2721,2822",
+ "endColumns": "109,102,110,83,102,114,78,77,92,94,95,93,102,94,96,98,92,89,80,111,102,97,109,103,108,160,100,80",
+ "endOffsets": "210,313,424,508,611,726,805,883,976,1071,1167,1261,1364,1459,1556,1655,1748,1838,1919,2031,2134,2232,2342,2446,2555,2716,2817,2898"
+ }
+ }
+ ]
+ },
+ {
+ "outputFile": "E:\\Note\\src\\app\\build\\intermediates\\res\\merged\\debug\\values-iw_values-iw.arsc.flat",
+ "map": [
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\6d11613c3b6a00a9ea456b5609ec43f7\\core-1.0.0\\res\\values-iw\\values-iw.xml",
+ "from": {
+ "startLines": "2",
+ "startColumns": "4",
+ "startOffsets": "55",
+ "endColumns": "100",
+ "endOffsets": "151"
+ },
+ "to": {
+ "startLines": "30",
+ "startColumns": "4",
+ "startOffsets": "2832",
+ "endColumns": "100",
+ "endOffsets": "2928"
+ }
+ },
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\88c548461109b0c917067cfea58751b3\\appcompat-1.0.0-alpha1\\res\\values-iw\\values-iw.xml",
+ "from": {
+ "startLines": "2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19,20,21,22,23,24,25,26,27,28,29",
+ "startColumns": "4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4",
+ "startOffsets": "105,209,308,416,500,600,714,792,870,961,1055,1151,1245,1346,1439,1534,1631,1722,1814,1895,1997,2101,2199,2302,2403,2503,2655,2751",
+ "endColumns": "103,98,107,83,99,113,77,77,90,93,95,93,100,92,94,96,90,91,80,101,103,97,102,100,99,151,95,80",
+ "endOffsets": "204,303,411,495,595,709,787,865,956,1050,1146,1240,1341,1434,1529,1626,1717,1809,1890,1992,2096,2194,2297,2398,2498,2650,2746,2827"
+ }
+ }
+ ]
+ },
+ {
+ "outputFile": "E:\\Note\\src\\app\\build\\intermediates\\res\\merged\\debug\\values-de_values-de.arsc.flat",
+ "map": [
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\88c548461109b0c917067cfea58751b3\\appcompat-1.0.0-alpha1\\res\\values-de\\values-de.xml",
+ "from": {
+ "startLines": "2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19,20,21,22,23,24,25,26,27,28,29",
+ "startColumns": "4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4",
+ "startOffsets": "105,210,308,420,506,611,726,803,879,971,1065,1162,1263,1371,1471,1575,1675,1773,1870,1952,2063,2166,2265,2376,2478,2585,2741,2843",
+ "endColumns": "104,97,111,85,104,114,76,75,91,93,96,100,107,99,103,99,97,96,81,110,102,98,110,101,106,155,101,81",
+ "endOffsets": "205,303,415,501,606,721,798,874,966,1060,1157,1258,1366,1466,1570,1670,1768,1865,1947,2058,2161,2260,2371,2473,2580,2736,2838,2920"
+ }
+ },
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\6d11613c3b6a00a9ea456b5609ec43f7\\core-1.0.0\\res\\values-de\\values-de.xml",
+ "from": {
+ "startLines": "2",
+ "startColumns": "4",
+ "startOffsets": "55",
+ "endColumns": "100",
+ "endOffsets": "151"
+ },
+ "to": {
+ "startLines": "30",
+ "startColumns": "4",
+ "startOffsets": "2925",
+ "endColumns": "100",
+ "endOffsets": "3021"
+ }
+ }
+ ]
+ },
+ {
+ "outputFile": "E:\\Note\\src\\app\\build\\intermediates\\res\\merged\\debug\\values-sv_values-sv.arsc.flat",
+ "map": [
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\6d11613c3b6a00a9ea456b5609ec43f7\\core-1.0.0\\res\\values-sv\\values-sv.xml",
+ "from": {
+ "startLines": "2",
+ "startColumns": "4",
+ "startOffsets": "55",
+ "endColumns": "100",
+ "endOffsets": "151"
+ },
+ "to": {
+ "startLines": "30",
+ "startColumns": "4",
+ "startOffsets": "2863",
+ "endColumns": "100",
+ "endOffsets": "2959"
+ }
+ },
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\88c548461109b0c917067cfea58751b3\\appcompat-1.0.0-alpha1\\res\\values-sv\\values-sv.xml",
+ "from": {
+ "startLines": "2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19,20,21,22,23,24,25,26,27,28,29",
+ "startColumns": "4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4",
+ "startOffsets": "105,211,314,425,510,612,725,801,877,970,1065,1161,1255,1358,1453,1550,1648,1744,1837,1917,2023,2123,2219,2324,2426,2528,2682,2784",
+ "endColumns": "105,102,110,84,101,112,75,75,92,94,95,93,102,94,96,97,95,92,79,105,99,95,104,101,101,153,101,78",
+ "endOffsets": "206,309,420,505,607,720,796,872,965,1060,1156,1250,1353,1448,1545,1643,1739,1832,1912,2018,2118,2214,2319,2421,2523,2677,2779,2858"
+ }
+ }
+ ]
+ },
+ {
+ "outputFile": "E:\\Note\\src\\app\\build\\intermediates\\res\\merged\\debug\\values-az_values-az.arsc.flat",
+ "map": [
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\6d11613c3b6a00a9ea456b5609ec43f7\\core-1.0.0\\res\\values-az\\values-az.xml",
+ "from": {
+ "startLines": "2",
+ "startColumns": "4",
+ "startOffsets": "55",
+ "endColumns": "100",
+ "endOffsets": "151"
+ },
+ "to": {
+ "startLines": "30",
+ "startColumns": "4",
+ "startOffsets": "2903",
+ "endColumns": "100",
+ "endOffsets": "2999"
+ }
+ },
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\88c548461109b0c917067cfea58751b3\\appcompat-1.0.0-alpha1\\res\\values-az\\values-az.xml",
+ "from": {
+ "startLines": "2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19,20,21,22,23,24,25,26,27,28,29",
+ "startColumns": "4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4",
+ "startOffsets": "105,213,312,424,512,619,733,814,893,984,1077,1172,1271,1372,1465,1560,1655,1746,1838,1923,2030,2137,2237,2346,2450,2560,2718,2820",
+ "endColumns": "107,98,111,87,106,113,80,78,90,92,94,98,100,92,94,94,90,91,84,106,106,99,108,103,109,157,101,82",
+ "endOffsets": "208,307,419,507,614,728,809,888,979,1072,1167,1266,1367,1460,1555,1650,1741,1833,1918,2025,2132,2232,2341,2445,2555,2713,2815,2898"
+ }
+ }
+ ]
+ },
+ {
+ "outputFile": "E:\\Note\\src\\app\\build\\intermediates\\res\\merged\\debug\\values-kk_values-kk.arsc.flat",
+ "map": [
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\6d11613c3b6a00a9ea456b5609ec43f7\\core-1.0.0\\res\\values-kk\\values-kk.xml",
+ "from": {
+ "startLines": "2",
+ "startColumns": "4",
+ "startOffsets": "55",
+ "endColumns": "100",
+ "endOffsets": "151"
+ },
+ "to": {
+ "startLines": "30",
+ "startColumns": "4",
+ "startOffsets": "2893",
+ "endColumns": "100",
+ "endOffsets": "2989"
+ }
+ },
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\88c548461109b0c917067cfea58751b3\\appcompat-1.0.0-alpha1\\res\\values-kk\\values-kk.xml",
+ "from": {
+ "startLines": "2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19,20,21,22,23,24,25,26,27,28,29",
+ "startColumns": "4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4",
+ "startOffsets": "105,217,320,430,515,621,740,821,901,992,1085,1181,1275,1376,1469,1564,1661,1752,1844,1925,2028,2133,2231,2338,2447,2547,2713,2812",
+ "endColumns": "111,102,109,84,105,118,80,79,90,92,95,93,100,92,94,96,90,91,80,102,104,97,106,108,99,165,98,80",
+ "endOffsets": "212,315,425,510,616,735,816,896,987,1080,1176,1270,1371,1464,1559,1656,1747,1839,1920,2023,2128,2226,2333,2442,2542,2708,2807,2888"
+ }
+ }
+ ]
+ },
+ {
+ "outputFile": "E:\\Note\\src\\app\\build\\intermediates\\res\\merged\\debug\\values-nb_values-nb.arsc.flat",
+ "map": [
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\88c548461109b0c917067cfea58751b3\\appcompat-1.0.0-alpha1\\res\\values-nb\\values-nb.xml",
+ "from": {
+ "startLines": "2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19,20,21,22,23,24,25,26,27,28,29",
+ "startColumns": "4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4",
+ "startOffsets": "105,213,308,422,508,608,721,797,873,964,1057,1153,1247,1348,1441,1536,1634,1725,1816,1896,1999,2098,2194,2298,2396,2497,2650,2747",
+ "endColumns": "107,94,113,85,99,112,75,75,90,92,95,93,100,92,94,97,90,90,79,102,98,95,103,97,100,152,96,78",
+ "endOffsets": "208,303,417,503,603,716,792,868,959,1052,1148,1242,1343,1436,1531,1629,1720,1811,1891,1994,2093,2189,2293,2391,2492,2645,2742,2821"
+ }
+ },
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\6d11613c3b6a00a9ea456b5609ec43f7\\core-1.0.0\\res\\values-nb\\values-nb.xml",
+ "from": {
+ "startLines": "2",
+ "startColumns": "4",
+ "startOffsets": "55",
+ "endColumns": "100",
+ "endOffsets": "151"
+ },
+ "to": {
+ "startLines": "30",
+ "startColumns": "4",
+ "startOffsets": "2826",
+ "endColumns": "100",
+ "endOffsets": "2922"
+ }
+ }
+ ]
+ },
+ {
+ "outputFile": "E:\\Note\\src\\app\\build\\intermediates\\res\\merged\\debug\\values-pl_values-pl.arsc.flat",
+ "map": [
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\6d11613c3b6a00a9ea456b5609ec43f7\\core-1.0.0\\res\\values-pl\\values-pl.xml",
+ "from": {
+ "startLines": "2",
+ "startColumns": "4",
+ "startOffsets": "55",
+ "endColumns": "100",
+ "endOffsets": "151"
+ },
+ "to": {
+ "startLines": "30",
+ "startColumns": "4",
+ "startOffsets": "2909",
+ "endColumns": "100",
+ "endOffsets": "3005"
+ }
+ },
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\88c548461109b0c917067cfea58751b3\\appcompat-1.0.0-alpha1\\res\\values-pl\\values-pl.xml",
+ "from": {
+ "startLines": "2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19,20,21,22,23,24,25,26,27,28,29",
+ "startColumns": "4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4",
+ "startOffsets": "105,221,323,431,517,626,745,823,900,991,1084,1180,1274,1376,1469,1564,1659,1750,1841,1923,2032,2141,2240,2349,2460,2568,2731,2827",
+ "endColumns": "115,101,107,85,108,118,77,76,90,92,95,93,101,92,94,94,90,90,81,108,108,98,108,110,107,162,95,81",
+ "endOffsets": "216,318,426,512,621,740,818,895,986,1079,1175,1269,1371,1464,1559,1654,1745,1836,1918,2027,2136,2235,2344,2455,2563,2726,2822,2904"
+ }
+ }
+ ]
+ },
+ {
+ "outputFile": "E:\\Note\\src\\app\\build\\intermediates\\res\\merged\\debug\\values-v26_values-v26.arsc.flat",
+ "map": [
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\88c548461109b0c917067cfea58751b3\\appcompat-1.0.0-alpha1\\res\\values-v26\\values-v26.xml",
+ "from": {
+ "startLines": "2,3,4,8,12,16",
+ "startColumns": "4,4,4,4,4,4",
+ "startOffsets": "55,130,217,431,657,896",
+ "endLines": "2,3,7,11,15,16",
+ "endColumns": "74,86,12,12,12,92",
+ "endOffsets": "125,212,426,652,891,984"
+ }
+ }
+ ]
+ },
+ {
+ "outputFile": "E:\\Note\\src\\app\\build\\intermediates\\res\\merged\\debug\\values-large-v4_values-large-v4.arsc.flat",
+ "map": [
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\88c548461109b0c917067cfea58751b3\\appcompat-1.0.0-alpha1\\res\\values-large-v4\\values-large-v4.xml",
+ "from": {
+ "startLines": "2,3,4,5,6,7,8,9,10",
+ "startColumns": "4,4,4,4,4,4,4,4,4",
+ "startOffsets": "55,114,185,256,326,396,464,532,636",
+ "endColumns": "58,70,70,69,69,67,67,103,115",
+ "endOffsets": "109,180,251,321,391,459,527,631,747"
+ }
+ }
+ ]
+ },
+ {
+ "outputFile": "E:\\Note\\src\\app\\build\\intermediates\\res\\merged\\debug\\values_values.arsc.flat",
+ "map": [
+ {
+ "source": "E:\\Note\\src\\app\\src\\main\\res\\values\\colors.xml",
+ "from": {
+ "startLines": "18",
+ "startColumns": "4",
+ "startOffsets": "730",
+ "endColumns": "56",
+ "endOffsets": "782"
+ },
+ "to": {
+ "startLines": "83",
+ "startColumns": "4",
+ "startOffsets": "5347",
+ "endColumns": "56",
+ "endOffsets": "5399"
+ }
+ },
+ {
+ "source": "E:\\Note\\src\\app\\src\\main\\res\\values\\arrays.xml",
+ "from": {
+ "startLines": "19,26",
+ "startColumns": "4,4",
+ "startOffsets": "758,1073",
+ "endLines": "24,29",
+ "endColumns": "19,19",
+ "endOffsets": "1065,1191"
+ },
+ "to": {
+ "startLines": "2,8",
+ "startColumns": "4,4",
+ "startOffsets": "105,412",
+ "endLines": "7,11",
+ "endColumns": "19,19",
+ "endOffsets": "407,527"
+ }
+ },
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\88c548461109b0c917067cfea58751b3\\appcompat-1.0.0-alpha1\\res\\values\\values.xml",
+ "from": {
+ "startLines": "2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19,20,21,22,23,24,25,26,27,28,29,30,31,32,33,34,35,36,37,38,39,40,41,42,43,44,45,46,47,48,49,50,51,52,53,54,55,56,57,58,59,60,61,62,63,64,65,66,67,68,1233,1234,1235,1236,1237,1238,1239,1240,1241,1242,1243,1244,1245,1246,1247,1248,1249,1250,1251,1252,1253,1254,1255,1256,1257,1258,1259,1260,1261,1262,1263,1264,1265,1266,1267,1268,1269,1270,1271,1272,1273,1274,1275,1276,1277,1278,1279,1280,1281,1282,1283,1284,1285,1286,1287,1288,1289,1290,1291,1292,1293,1294,1295,1296,1297,1298,1299,1300,1301,1302,1303,1304,1305,1306,1307,1308,1309,1310,1311,1312,1313,1314,1315,1316,1317,1318,1319,1320,1321,1322,1323,1324,1325,1326,1327,1328,1329,1330,1331,1332,1333,1334,1335,1336,1337,1338,1339,1340,1341,1342,1343,1344,1345,1346,1347,1348,1349,1350,1351,1352,1353,1354,1355,1356,1357,1358,1359,1360,1361,1362,1363,1364,1365,1366,1367,1368,1369,1370,1371,1372,1373,1374,1375,1376,1377,1378,1379,1380,1381,1382,1383,1391,1392,1396,1400,1404,1409,1415,1422,1426,1430,1435,1439,1443,1447,1451,1455,1459,1465,1469,1475,1479,1485,1489,1494,1498,1501,1505,1511,1515,1521,1525,1531,1534,1538,1542,1546,1550,1554,1555,1556,1557,1560,1563,1566,1569,1573,1574,1575,1576,1577,1580,1582,1584,1586,1591,1592,1596,1602,1606,1607,1609,1620,1621,1625,1631,1635,1636,1637,1641,1668,1672,1673,1677,1705,1873,1899,2068,2094,2125,2133,2139,2153,2175,2180,2185,2195,2204,2213,2217,2224,2232,2239,2240,2249,2252,2255,2259,2263,2267,2270,2271,2275,2279,2289,2294,2301,2307,2308,2311,2315,2320,2322,2324,2327,2330,2332,2336,2339,2346,2349,2352,2356,2358,2362,2364,2366,2368,2372,2380,2388,2400,2406,2415,2418,2429,2432,2437,2438,2443,2501,2560,2561,2571,2580,2581,2583,2587,2590,2593,2596,2599,2602,2605,2608,2612,2615,2618,2621,2625,2628,2632,2636,2637,2638,2639,2640,2641,2642,2643,2644,2645,2646,2647,2648,2649,2650,2651,2652,2653,2654,2655,2656,2658,2660,2661,2662,2663,2664,2665,2666,2667,2669,2670,2672,2673,2675,2677,2678,2680,2681,2682,2683,2684,2685,2687,2688,2689,2690,2691,2692,2694,2696,2698,2699,2700,2701,2702,2703,2704,2705,2706,2707,2708,2709,2710,2712,2713,2714,2715,2716,2717,2719,2723,2727,2728,2729,2730,2731,2732,2733,2734,2736,2738,2740,2742,2744,2745,2746,2747,2749,2751,2753,2754,2755,2756,2757,2758,2759,2760,2761,2762,2763,2764,2767,2768,2769,2770,2772,2774,2775,2777,2778,2780,2782,2784,2785,2786,2787,2788,2789,2790,2791,2792,2793,2794,2795,2797,2798,2799,2800,2802,2803,2804,2805,2806,2808,2810,2812,2814,2815,2816,2817,2818,2819,2820,2821,2822,2823,2824,2825,2826,2827,69,152,155,158,161,175,186,196,226,253,262,299,680,692,718,736,772,778,784,807,948,968,974,978,984,1021,1033,1099,1114,1179,1198,1224",
+ "startColumns": "4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4",
+ "startOffsets": "105,160,205,254,295,350,409,471,552,613,688,764,841,919,1004,1086,1162,1238,1315,1393,1499,1605,1684,1764,1821,1879,1953,2028,2093,2159,2219,2280,2352,2425,2492,2560,2619,2678,2737,2796,2855,2909,2963,3016,3070,3124,3178,3232,3306,3385,3458,3532,3603,3675,3747,3820,3877,3935,4008,4082,4156,4231,4303,4376,4446,4517,4577,66677,66746,66815,66885,66959,67035,67099,67176,67252,67329,67394,67463,67540,67615,67684,67752,67829,67895,67956,68053,68118,68187,68286,68357,68416,68474,68531,68590,68654,68725,68797,68869,68941,69013,69080,69148,69216,69275,69338,69402,69492,69583,69643,69709,69776,69842,69912,69976,70029,70142,70200,70263,70328,70393,70468,70541,70613,70662,70723,70784,70845,70907,70971,71035,71099,71164,71227,71287,71348,71414,71473,71533,71595,71666,71726,71794,71880,71967,72057,72144,72232,72314,72397,72487,72578,72630,72688,72733,72799,72863,72920,72977,73031,73088,73136,73185,73236,73270,73317,73366,73412,73444,73508,73570,73630,73687,73761,73831,73909,73963,74033,74118,74166,74212,74283,74361,74439,74511,74585,74659,74733,74813,74886,74955,75027,75104,75165,75228,75294,75358,75429,75492,75557,75621,75682,75743,75795,75868,75942,76011,76086,76160,76234,76375,76445,76498,76576,76666,76754,76850,76940,77522,77611,77858,78139,78391,78676,79069,79546,79768,79990,80266,80493,80723,80953,81183,81413,81640,82059,82285,82710,82940,83368,83587,83870,84078,84209,84436,84862,85087,85514,85735,86160,86280,86556,86857,87181,87472,87786,87923,88054,88159,88401,88568,88772,88980,89251,89363,89475,89580,89697,89911,90057,90197,90283,90631,90719,90965,91383,91632,91714,91812,92429,92529,92781,93205,93460,93554,93643,93880,95932,96174,96276,96529,98713,109434,110950,121770,123298,125055,125681,126101,127162,128427,128683,128919,129466,129960,130565,130763,131343,131907,132282,132400,132938,133095,133291,133564,133820,133990,134131,134195,134477,134763,135439,135703,136041,136394,136488,136674,136980,137242,137367,137494,137733,137944,138063,138256,138433,138888,139069,139191,139450,139563,139750,139852,139959,140088,140363,140871,141367,142244,142538,143108,143257,143989,144161,144497,144589,144867,149211,153698,153760,154390,155004,155095,155208,155437,155597,155749,155920,156086,156255,156422,156585,156828,156998,157171,157342,157616,157815,158020,158350,158434,158530,158626,158724,158824,158926,159028,159130,159232,159334,159434,159530,159642,159771,159894,160025,160156,160254,160368,160462,160602,160736,160832,160944,161044,161160,161256,161368,161468,161608,161744,161908,162038,162196,162346,162487,162631,162766,162878,163028,163156,163284,163420,163552,163682,163812,163924,164064,164210,164354,164492,164558,164648,164724,164828,164918,165020,165128,165236,165336,165416,165508,165606,165716,165794,165900,165992,166096,166206,166328,166491,166648,166728,166828,166918,167028,167122,167228,167320,167420,167532,167646,167762,167878,167972,168086,168198,168300,168420,168542,168624,168728,168848,168974,169072,169166,169254,169366,169482,169604,169716,169891,170007,170093,170185,170297,170421,170488,170614,170682,170810,170954,171082,171151,171246,171361,171474,171573,171682,171793,171904,172005,172110,172210,172340,172431,172554,172648,172760,172846,172950,173046,173134,173252,173356,173460,173586,173674,173782,173882,173972,174082,174166,174268,174352,174406,174470,174576,174686,174770,4638,9782,9900,10015,10147,10862,11554,12071,13670,15203,15591,17898,37416,37974,39366,40399,42412,42674,43030,43860,50642,51776,52070,52293,52620,54670,55318,59169,59770,63579,64794,66203",
+ "endLines": "2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19,20,21,22,23,24,25,26,27,28,29,30,31,32,33,34,35,36,37,38,39,40,41,42,43,44,45,46,47,48,49,50,51,52,53,54,55,56,57,58,59,60,61,62,63,64,65,66,67,68,1233,1234,1235,1236,1237,1238,1239,1240,1241,1242,1243,1244,1245,1246,1247,1248,1249,1250,1251,1252,1253,1254,1255,1256,1257,1258,1259,1260,1261,1262,1263,1264,1265,1266,1267,1268,1269,1270,1271,1272,1273,1274,1275,1276,1277,1278,1279,1280,1281,1282,1283,1284,1285,1286,1287,1288,1289,1290,1291,1292,1293,1294,1295,1296,1297,1298,1299,1300,1301,1302,1303,1304,1305,1306,1307,1308,1309,1310,1311,1312,1313,1314,1315,1316,1317,1318,1319,1320,1321,1322,1323,1324,1325,1326,1327,1328,1329,1330,1331,1332,1333,1334,1335,1336,1337,1338,1339,1340,1341,1342,1343,1344,1345,1346,1347,1348,1349,1350,1351,1352,1353,1354,1355,1356,1357,1358,1359,1360,1361,1362,1363,1364,1365,1366,1367,1368,1369,1370,1371,1372,1373,1374,1375,1376,1377,1378,1379,1380,1381,1382,1390,1391,1395,1399,1403,1408,1414,1421,1425,1429,1434,1438,1442,1446,1450,1454,1458,1464,1468,1474,1478,1484,1488,1493,1497,1500,1504,1510,1514,1520,1524,1530,1533,1537,1541,1545,1549,1553,1554,1555,1556,1559,1562,1565,1568,1572,1573,1574,1575,1576,1579,1581,1583,1585,1590,1591,1595,1601,1605,1606,1608,1619,1620,1624,1630,1634,1635,1636,1640,1667,1671,1672,1676,1704,1872,1898,2067,2093,2124,2132,2138,2152,2174,2179,2184,2194,2203,2212,2216,2223,2231,2238,2239,2248,2251,2254,2258,2262,2266,2269,2270,2274,2278,2288,2293,2300,2306,2307,2310,2314,2319,2321,2323,2326,2329,2331,2335,2338,2345,2348,2351,2355,2357,2361,2363,2365,2367,2371,2379,2387,2399,2405,2414,2417,2428,2431,2436,2437,2442,2500,2559,2560,2570,2579,2580,2582,2586,2589,2592,2595,2598,2601,2604,2607,2611,2614,2617,2620,2624,2627,2631,2635,2636,2637,2638,2639,2640,2641,2642,2643,2644,2645,2646,2647,2648,2649,2650,2651,2652,2653,2654,2655,2657,2659,2660,2661,2662,2663,2664,2665,2666,2668,2669,2671,2672,2674,2676,2677,2679,2680,2681,2682,2683,2684,2686,2687,2688,2689,2690,2691,2693,2695,2697,2698,2699,2700,2701,2702,2703,2704,2705,2706,2707,2708,2709,2711,2712,2713,2714,2715,2716,2718,2722,2726,2727,2728,2729,2730,2731,2732,2733,2735,2737,2739,2741,2743,2744,2745,2746,2748,2750,2752,2753,2754,2755,2756,2757,2758,2759,2760,2761,2762,2763,2766,2767,2768,2769,2771,2773,2774,2776,2777,2779,2781,2783,2784,2785,2786,2787,2788,2789,2790,2791,2792,2793,2794,2796,2797,2798,2799,2801,2802,2803,2804,2805,2807,2809,2811,2813,2814,2815,2816,2817,2818,2819,2820,2821,2822,2823,2824,2825,2826,2827,151,154,157,160,174,185,195,225,252,261,298,679,684,717,735,771,777,783,806,947,967,973,977,983,1020,1032,1098,1113,1178,1197,1223,1232",
+ "endColumns": "54,44,48,40,54,58,61,80,60,74,75,76,77,84,81,75,75,76,77,105,105,78,79,56,57,73,74,64,65,59,60,71,72,66,67,58,58,58,58,58,53,53,52,53,53,53,53,73,78,72,73,70,71,71,72,56,57,72,73,73,74,71,72,69,70,59,60,68,68,69,73,75,63,76,75,76,64,68,76,74,68,67,76,65,60,96,64,68,98,70,58,57,56,58,63,70,71,71,71,71,66,67,67,58,62,63,89,90,59,65,66,65,69,63,52,112,57,62,64,64,74,72,71,48,60,60,60,61,63,63,63,64,62,59,60,65,58,59,61,70,59,67,85,86,89,86,87,81,82,89,90,51,57,44,65,63,56,56,53,56,47,48,50,33,46,48,45,31,63,61,59,56,73,69,77,53,69,84,47,45,70,77,77,71,73,73,73,79,72,68,71,76,60,62,65,63,70,62,64,63,60,60,51,72,73,68,74,73,73,140,69,52,77,89,87,95,89,12,88,12,12,12,12,12,12,12,12,12,12,12,12,12,12,12,12,12,12,12,12,12,12,12,12,12,12,12,12,12,12,12,12,12,12,12,12,136,130,104,12,12,12,12,12,111,111,104,116,12,12,12,12,12,87,12,12,12,81,12,12,99,12,12,12,93,88,12,12,12,101,12,12,12,12,12,12,12,12,12,12,12,12,12,12,12,12,12,12,12,12,117,12,12,12,12,12,12,12,63,12,12,12,12,12,12,93,12,12,12,12,12,12,12,12,12,12,12,12,12,12,12,12,12,12,12,12,12,12,12,12,12,12,12,12,12,91,12,12,12,61,12,12,90,12,12,12,12,12,12,12,12,12,12,12,12,12,12,12,12,12,83,95,95,97,99,101,101,101,101,101,99,95,111,128,122,130,130,97,113,93,12,12,95,111,99,115,95,111,99,12,135,12,129,12,12,140,12,134,111,149,127,127,12,131,129,129,111,139,12,12,12,65,89,75,103,89,101,107,107,99,79,91,97,12,77,105,91,103,109,12,12,12,79,99,89,109,93,105,91,12,12,12,12,12,93,113,111,12,12,12,81,103,119,125,97,93,87,111,115,121,111,12,115,85,91,12,12,66,12,67,12,12,12,68,94,114,112,98,108,110,110,100,104,99,12,90,122,93,12,85,103,95,87,12,12,12,12,87,107,99,89,109,83,101,83,53,63,105,109,83,119,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24",
+ "endOffsets": "155,200,249,290,345,404,466,547,608,683,759,836,914,999,1081,1157,1233,1310,1388,1494,1600,1679,1759,1816,1874,1948,2023,2088,2154,2214,2275,2347,2420,2487,2555,2614,2673,2732,2791,2850,2904,2958,3011,3065,3119,3173,3227,3301,3380,3453,3527,3598,3670,3742,3815,3872,3930,4003,4077,4151,4226,4298,4371,4441,4512,4572,4633,66741,66810,66880,66954,67030,67094,67171,67247,67324,67389,67458,67535,67610,67679,67747,67824,67890,67951,68048,68113,68182,68281,68352,68411,68469,68526,68585,68649,68720,68792,68864,68936,69008,69075,69143,69211,69270,69333,69397,69487,69578,69638,69704,69771,69837,69907,69971,70024,70137,70195,70258,70323,70388,70463,70536,70608,70657,70718,70779,70840,70902,70966,71030,71094,71159,71222,71282,71343,71409,71468,71528,71590,71661,71721,71789,71875,71962,72052,72139,72227,72309,72392,72482,72573,72625,72683,72728,72794,72858,72915,72972,73026,73083,73131,73180,73231,73265,73312,73361,73407,73439,73503,73565,73625,73682,73756,73826,73904,73958,74028,74113,74161,74207,74278,74356,74434,74506,74580,74654,74728,74808,74881,74950,75022,75099,75160,75223,75289,75353,75424,75487,75552,75616,75677,75738,75790,75863,75937,76006,76081,76155,76229,76370,76440,76493,76571,76661,76749,76845,76935,77517,77606,77853,78134,78386,78671,79064,79541,79763,79985,80261,80488,80718,80948,81178,81408,81635,82054,82280,82705,82935,83363,83582,83865,84073,84204,84431,84857,85082,85509,85730,86155,86275,86551,86852,87176,87467,87781,87918,88049,88154,88396,88563,88767,88975,89246,89358,89470,89575,89692,89906,90052,90192,90278,90626,90714,90960,91378,91627,91709,91807,92424,92524,92776,93200,93455,93549,93638,93875,95927,96169,96271,96524,98708,109429,110945,121765,123293,125050,125676,126096,127157,128422,128678,128914,129461,129955,130560,130758,131338,131902,132277,132395,132933,133090,133286,133559,133815,133985,134126,134190,134472,134758,135434,135698,136036,136389,136483,136669,136975,137237,137362,137489,137728,137939,138058,138251,138428,138883,139064,139186,139445,139558,139745,139847,139954,140083,140358,140866,141362,142239,142533,143103,143252,143984,144156,144492,144584,144862,149206,153693,153755,154385,154999,155090,155203,155432,155592,155744,155915,156081,156250,156417,156580,156823,156993,157166,157337,157611,157810,158015,158345,158429,158525,158621,158719,158819,158921,159023,159125,159227,159329,159429,159525,159637,159766,159889,160020,160151,160249,160363,160457,160597,160731,160827,160939,161039,161155,161251,161363,161463,161603,161739,161903,162033,162191,162341,162482,162626,162761,162873,163023,163151,163279,163415,163547,163677,163807,163919,164059,164205,164349,164487,164553,164643,164719,164823,164913,165015,165123,165231,165331,165411,165503,165601,165711,165789,165895,165987,166091,166201,166323,166486,166643,166723,166823,166913,167023,167117,167223,167315,167415,167527,167641,167757,167873,167967,168081,168193,168295,168415,168537,168619,168723,168843,168969,169067,169161,169249,169361,169477,169599,169711,169886,170002,170088,170180,170292,170416,170483,170609,170677,170805,170949,171077,171146,171241,171356,171469,171568,171677,171788,171899,172000,172105,172205,172335,172426,172549,172643,172755,172841,172945,173041,173129,173247,173351,173455,173581,173669,173777,173877,173967,174077,174161,174263,174347,174401,174465,174571,174681,174765,174885,9777,9895,10010,10142,10857,11549,12066,13665,15198,15586,17893,37411,37671,39361,40394,42407,42669,43025,43855,50637,51771,52065,52288,52615,54665,55313,59164,59765,63574,64789,66198,66672"
+ },
+ "to": {
+ "startLines": "13,14,15,16,17,18,19,20,21,22,23,24,25,26,27,28,29,30,31,32,33,34,35,36,37,38,39,40,41,42,43,44,45,46,47,48,49,50,51,52,53,54,55,56,57,58,59,63,64,65,66,67,68,69,70,71,72,73,74,75,76,77,78,79,80,81,82,84,85,86,87,88,89,90,91,92,93,94,95,96,97,98,99,100,101,102,103,104,105,106,107,108,109,110,111,112,113,114,115,116,117,118,119,120,121,122,123,124,125,126,127,128,129,130,131,132,133,134,135,136,137,138,139,140,141,142,143,144,145,146,147,148,149,150,151,152,153,154,155,156,157,158,166,167,168,169,170,171,172,173,174,199,200,201,202,203,204,205,206,209,210,211,212,213,216,217,218,225,226,227,228,229,236,237,238,239,240,241,242,243,244,245,246,247,248,249,250,251,252,253,254,255,256,257,258,259,260,261,262,263,264,265,266,267,268,269,270,271,272,273,274,371,388,389,390,391,392,393,401,402,406,410,414,419,425,432,436,440,445,449,453,457,461,465,469,475,479,485,489,495,499,504,508,511,515,521,525,531,535,541,544,548,552,556,560,564,565,566,567,570,573,576,579,583,584,585,586,587,590,592,594,596,601,602,606,612,616,617,619,630,631,635,641,645,646,647,651,678,682,683,687,715,883,909,1078,1104,1135,1143,1149,1163,1185,1190,1195,1205,1214,1223,1227,1234,1242,1249,1250,1259,1262,1265,1269,1273,1277,1280,1281,1285,1289,1299,1304,1311,1317,1318,1321,1325,1330,1332,1334,1337,1340,1342,1346,1349,1356,1359,1362,1366,1368,1372,1374,1376,1378,1382,1390,1398,1410,1416,1425,1428,1439,1442,1447,1448,1467,1525,1584,1585,1595,1604,1605,1607,1611,1614,1617,1620,1623,1626,1629,1632,1636,1639,1642,1645,1649,1652,1656,1660,1661,1662,1663,1664,1665,1666,1667,1668,1669,1670,1671,1672,1673,1674,1675,1676,1677,1678,1679,1680,1682,1684,1685,1686,1687,1688,1689,1690,1691,1693,1694,1696,1697,1699,1701,1702,1704,1705,1706,1707,1708,1709,1711,1712,1713,1714,1715,1732,1734,1736,1766,1767,1768,1769,1770,1771,1772,1773,1774,1775,1776,1777,1778,1780,1781,1782,1783,1784,1785,1787,1791,1795,1796,1797,1798,1799,1800,1801,1802,1804,1806,1808,1810,1812,1813,1814,1815,1817,1819,1821,1822,1823,1824,1825,1826,1827,1828,1829,1830,1831,1832,1835,1836,1837,1838,1840,1842,1843,1845,1846,1848,1850,1852,1853,1854,1855,1856,1857,1858,1859,1860,1861,1862,1863,1865,1866,1867,1868,1870,1871,1872,1873,1874,1876,1878,1880,1882,1883,1884,1885,1886,1887,1888,1889,1890,1891,1892,1893,1894,1895,1901,1984,1987,1990,1993,2007,2018,2028,2058,2085,2094,2131,2512,2518,2643,2780,2816,2822,2828,2851,2992,3012,3018,3022,3028,3065,3077,3143,3158,3223,3242,3268",
+ "startColumns": "4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4",
+ "startOffsets": "593,648,693,742,783,838,897,959,1040,1101,1176,1252,1329,1407,1492,1574,1650,1726,1803,1881,1987,2093,2172,2252,2309,2367,2441,2516,2581,2647,2707,2768,2840,2913,2980,3048,3107,3166,3225,3284,3343,3397,3451,3504,3558,3612,3666,3941,4015,4094,4167,4241,4312,4384,4456,4529,4586,4644,4717,4791,4865,4940,5012,5085,5155,5226,5286,5404,5473,5542,5612,5686,5762,5826,5903,5979,6056,6121,6190,6267,6342,6411,6479,6556,6622,6683,6780,6845,6914,7013,7084,7143,7201,7258,7317,7381,7452,7524,7596,7668,7740,7807,7875,7943,8002,8065,8129,8219,8310,8370,8436,8503,8569,8639,8703,8756,8869,8927,8990,9055,9120,9195,9268,9340,9389,9450,9511,9572,9634,9698,9762,9826,9891,9954,10014,10075,10141,10200,10260,10322,10393,10453,11009,11095,11182,11272,11359,11447,11529,11612,11702,13245,13297,13355,13400,13466,13530,13587,13644,13846,13903,13951,14000,14051,14155,14202,14251,14569,14601,14665,14727,14787,15307,15381,15451,15529,15583,15653,15738,15786,15832,15903,15981,16059,16131,16205,16279,16353,16433,16506,16575,16647,16724,16785,16848,16914,16978,17049,17112,17177,17241,17302,17363,17415,17488,17562,17631,17706,17780,17854,17995,24560,25758,25836,25926,26014,26110,26200,26782,26871,27118,27399,27651,27936,28329,28806,29028,29250,29526,29753,29983,30213,30443,30673,30900,31319,31545,31970,32200,32628,32847,33130,33338,33469,33696,34122,34347,34774,34995,35420,35540,35816,36117,36441,36732,37046,37183,37314,37419,37661,37828,38032,38240,38511,38623,38735,38840,38957,39171,39317,39457,39543,39891,39979,40225,40643,40892,40974,41072,41689,41789,42041,42465,42720,42814,42903,43140,45192,45434,45536,45789,47973,58694,60210,71030,72558,74315,74941,75361,76422,77687,77943,78179,78726,79220,79825,80023,80603,81167,81542,81660,82198,82355,82551,82824,83080,83250,83391,83455,83737,84023,84699,84963,85301,85654,85748,85934,86240,86502,86627,86754,86993,87204,87323,87516,87693,88148,88329,88451,88710,88823,89010,89112,89219,89348,89623,90131,90627,91504,91798,92368,92517,93249,93421,93757,93849,94866,99210,103697,103759,104389,105003,105094,105207,105436,105596,105748,105919,106085,106254,106421,106584,106827,106997,107170,107341,107615,107814,108019,108349,108433,108529,108625,108723,108823,108925,109027,109129,109231,109333,109433,109529,109641,109770,109893,110024,110155,110253,110367,110461,110601,110735,110831,110943,111043,111159,111255,111367,111467,111607,111743,111907,112037,112195,112345,112486,112630,112765,112877,113027,113155,113283,113419,113551,113681,113811,113923,115203,115349,115493,116977,117043,117133,117209,117313,117403,117505,117613,117721,117821,117901,117993,118091,118201,118279,118385,118477,118581,118691,118813,118976,119133,119213,119313,119403,119513,119607,119713,119805,119905,120017,120131,120247,120363,120457,120571,120683,120785,120905,121027,121109,121213,121333,121459,121557,121651,121739,121851,121967,122089,122201,122376,122492,122578,122670,122782,122906,122973,123099,123167,123295,123439,123567,123636,123731,123846,123959,124058,124167,124278,124389,124490,124595,124695,124825,124916,125039,125133,125245,125331,125435,125531,125619,125737,125841,125945,126071,126159,126267,126367,126457,126567,126651,126753,126837,126891,126955,127061,127171,127255,127659,132803,132921,133036,133168,133883,134575,135092,136691,138224,138612,140919,160437,160858,168069,176210,178223,178485,178841,179671,186453,187587,187881,188104,188431,190481,191129,194980,195581,199390,200605,202014",
+ "endLines": "13,14,15,16,17,18,19,20,21,22,23,24,25,26,27,28,29,30,31,32,33,34,35,36,37,38,39,40,41,42,43,44,45,46,47,48,49,50,51,52,53,54,55,56,57,58,59,63,64,65,66,67,68,69,70,71,72,73,74,75,76,77,78,79,80,81,82,84,85,86,87,88,89,90,91,92,93,94,95,96,97,98,99,100,101,102,103,104,105,106,107,108,109,110,111,112,113,114,115,116,117,118,119,120,121,122,123,124,125,126,127,128,129,130,131,132,133,134,135,136,137,138,139,140,141,142,143,144,145,146,147,148,149,150,151,152,153,154,155,156,157,158,166,167,168,169,170,171,172,173,174,199,200,201,202,203,204,205,206,209,210,211,212,213,216,217,218,225,226,227,228,229,236,237,238,239,240,241,242,243,244,245,246,247,248,249,250,251,252,253,254,255,256,257,258,259,260,261,262,263,264,265,266,267,268,269,270,271,272,273,274,371,388,389,390,391,392,400,401,405,409,413,418,424,431,435,439,444,448,452,456,460,464,468,474,478,484,488,494,498,503,507,510,514,520,524,530,534,540,543,547,551,555,559,563,564,565,566,569,572,575,578,582,583,584,585,586,589,591,593,595,600,601,605,611,615,616,618,629,630,634,640,644,645,646,650,677,681,682,686,714,882,908,1077,1103,1134,1142,1148,1162,1184,1189,1194,1204,1213,1222,1226,1233,1241,1248,1249,1258,1261,1264,1268,1272,1276,1279,1280,1284,1288,1298,1303,1310,1316,1317,1320,1324,1329,1331,1333,1336,1339,1341,1345,1348,1355,1358,1361,1365,1367,1371,1373,1375,1377,1381,1389,1397,1409,1415,1424,1427,1438,1441,1446,1447,1452,1524,1583,1584,1594,1603,1604,1606,1610,1613,1616,1619,1622,1625,1628,1631,1635,1638,1641,1644,1648,1651,1655,1659,1660,1661,1662,1663,1664,1665,1666,1667,1668,1669,1670,1671,1672,1673,1674,1675,1676,1677,1678,1679,1681,1683,1684,1685,1686,1687,1688,1689,1690,1692,1693,1695,1696,1698,1700,1701,1703,1704,1705,1706,1707,1708,1710,1711,1712,1713,1714,1715,1733,1735,1737,1766,1767,1768,1769,1770,1771,1772,1773,1774,1775,1776,1777,1779,1780,1781,1782,1783,1784,1786,1790,1794,1795,1796,1797,1798,1799,1800,1801,1803,1805,1807,1809,1811,1812,1813,1814,1816,1818,1820,1821,1822,1823,1824,1825,1826,1827,1828,1829,1830,1831,1834,1835,1836,1837,1839,1841,1842,1844,1845,1847,1849,1851,1852,1853,1854,1855,1856,1857,1858,1859,1860,1861,1862,1864,1865,1866,1867,1869,1870,1871,1872,1873,1875,1877,1879,1881,1882,1883,1884,1885,1886,1887,1888,1889,1890,1891,1892,1893,1894,1895,1983,1986,1989,1992,2006,2017,2027,2057,2084,2093,2130,2511,2516,2543,2660,2815,2821,2827,2850,2991,3011,3017,3021,3027,3064,3076,3142,3157,3222,3241,3267,3276",
+ "endColumns": "54,44,48,40,54,58,61,80,60,74,75,76,77,84,81,75,75,76,77,105,105,78,79,56,57,73,74,64,65,59,60,71,72,66,67,58,58,58,58,58,53,53,52,53,53,53,53,73,78,72,73,70,71,71,72,56,57,72,73,73,74,71,72,69,70,59,60,68,68,69,73,75,63,76,75,76,64,68,76,74,68,67,76,65,60,96,64,68,98,70,58,57,56,58,63,70,71,71,71,71,66,67,67,58,62,63,89,90,59,65,66,65,69,63,52,112,57,62,64,64,74,72,71,48,60,60,60,61,63,63,63,64,62,59,60,65,58,59,61,70,59,67,85,86,89,86,87,81,82,89,90,51,57,44,65,63,56,56,53,56,47,48,50,33,46,48,45,31,63,61,59,56,73,69,77,53,69,84,47,45,70,77,77,71,73,73,73,79,72,68,71,76,60,62,65,63,70,62,64,63,60,60,51,72,73,68,74,73,73,140,69,52,77,89,87,95,89,12,88,12,12,12,12,12,12,12,12,12,12,12,12,12,12,12,12,12,12,12,12,12,12,12,12,12,12,12,12,12,12,12,12,12,12,12,12,136,130,104,12,12,12,12,12,111,111,104,116,12,12,12,12,12,87,12,12,12,81,12,12,99,12,12,12,93,88,12,12,12,101,12,12,12,12,12,12,12,12,12,12,12,12,12,12,12,12,12,12,12,12,117,12,12,12,12,12,12,12,63,12,12,12,12,12,12,93,12,12,12,12,12,12,12,12,12,12,12,12,12,12,12,12,12,12,12,12,12,12,12,12,12,12,12,12,12,91,12,12,12,61,12,12,90,12,12,12,12,12,12,12,12,12,12,12,12,12,12,12,12,12,83,95,95,97,99,101,101,101,101,101,99,95,111,128,122,130,130,97,113,93,12,12,95,111,99,115,95,111,99,12,135,12,129,12,12,140,12,134,111,149,127,127,12,131,129,129,111,139,12,12,12,65,89,75,103,89,101,107,107,99,79,91,97,12,77,105,91,103,109,12,12,12,79,99,89,109,93,105,91,12,12,12,12,12,93,113,111,12,12,12,81,103,119,125,97,93,87,111,115,121,111,12,115,85,91,12,12,66,12,67,12,12,12,68,94,114,112,98,108,110,110,100,104,99,12,90,122,93,12,85,103,95,87,12,12,12,12,87,107,99,89,109,83,101,83,53,63,105,109,83,119,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24",
+ "endOffsets": "643,688,737,778,833,892,954,1035,1096,1171,1247,1324,1402,1487,1569,1645,1721,1798,1876,1982,2088,2167,2247,2304,2362,2436,2511,2576,2642,2702,2763,2835,2908,2975,3043,3102,3161,3220,3279,3338,3392,3446,3499,3553,3607,3661,3715,4010,4089,4162,4236,4307,4379,4451,4524,4581,4639,4712,4786,4860,4935,5007,5080,5150,5221,5281,5342,5468,5537,5607,5681,5757,5821,5898,5974,6051,6116,6185,6262,6337,6406,6474,6551,6617,6678,6775,6840,6909,7008,7079,7138,7196,7253,7312,7376,7447,7519,7591,7663,7735,7802,7870,7938,7997,8060,8124,8214,8305,8365,8431,8498,8564,8634,8698,8751,8864,8922,8985,9050,9115,9190,9263,9335,9384,9445,9506,9567,9629,9693,9757,9821,9886,9949,10009,10070,10136,10195,10255,10317,10388,10448,10516,11090,11177,11267,11354,11442,11524,11607,11697,11788,13292,13350,13395,13461,13525,13582,13639,13693,13898,13946,13995,14046,14080,14197,14246,14292,14596,14660,14722,14782,14839,15376,15446,15524,15578,15648,15733,15781,15827,15898,15976,16054,16126,16200,16274,16348,16428,16501,16570,16642,16719,16780,16843,16909,16973,17044,17107,17172,17236,17297,17358,17410,17483,17557,17626,17701,17775,17849,17990,18060,24608,25831,25921,26009,26105,26195,26777,26866,27113,27394,27646,27931,28324,28801,29023,29245,29521,29748,29978,30208,30438,30668,30895,31314,31540,31965,32195,32623,32842,33125,33333,33464,33691,34117,34342,34769,34990,35415,35535,35811,36112,36436,36727,37041,37178,37309,37414,37656,37823,38027,38235,38506,38618,38730,38835,38952,39166,39312,39452,39538,39886,39974,40220,40638,40887,40969,41067,41684,41784,42036,42460,42715,42809,42898,43135,45187,45429,45531,45784,47968,58689,60205,71025,72553,74310,74936,75356,76417,77682,77938,78174,78721,79215,79820,80018,80598,81162,81537,81655,82193,82350,82546,82819,83075,83245,83386,83450,83732,84018,84694,84958,85296,85649,85743,85929,86235,86497,86622,86749,86988,87199,87318,87511,87688,88143,88324,88446,88705,88818,89005,89107,89214,89343,89618,90126,90622,91499,91793,92363,92512,93244,93416,93752,93844,94122,99205,103692,103754,104384,104998,105089,105202,105431,105591,105743,105914,106080,106249,106416,106579,106822,106992,107165,107336,107610,107809,108014,108344,108428,108524,108620,108718,108818,108920,109022,109124,109226,109328,109428,109524,109636,109765,109888,110019,110150,110248,110362,110456,110596,110730,110826,110938,111038,111154,111250,111362,111462,111602,111738,111902,112032,112190,112340,112481,112625,112760,112872,113022,113150,113278,113414,113546,113676,113806,113918,114058,115344,115488,115626,117038,117128,117204,117308,117398,117500,117608,117716,117816,117896,117988,118086,118196,118274,118380,118472,118576,118686,118808,118971,119128,119208,119308,119398,119508,119602,119708,119800,119900,120012,120126,120242,120358,120452,120566,120678,120780,120900,121022,121104,121208,121328,121454,121552,121646,121734,121846,121962,122084,122196,122371,122487,122573,122665,122777,122901,122968,123094,123162,123290,123434,123562,123631,123726,123841,123954,124053,124162,124273,124384,124485,124590,124690,124820,124911,125034,125128,125240,125326,125430,125526,125614,125732,125836,125940,126066,126154,126262,126362,126452,126562,126646,126748,126832,126886,126950,127056,127166,127250,127370,132798,132916,133031,133163,133878,134570,135087,136686,138219,138607,140914,160432,160692,162245,169097,178218,178480,178836,179666,186448,187582,187876,188099,188426,190476,191124,194975,195576,199385,200600,202009,202483"
+ }
+ },
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\702974eead929cb167f132efe0eabb04\\media-1.0.0\\res\\values\\values.xml",
+ "from": {
+ "startLines": "2,5,6,7,8,10,11,12,13,14",
+ "startColumns": "4,4,4,4,4,4,4,4,4,4",
+ "startOffsets": "55,288,341,394,447,560,626,748,809,875",
+ "endColumns": "88,52,52,52,52,65,121,60,65,66",
+ "endOffsets": "139,336,389,442,495,621,743,804,870,937"
+ },
+ "to": {
+ "startLines": "62,190,191,192,193,1721,1723,1724,1729,1731",
+ "startColumns": "4,4,4,4,4,4,4,4,4,4",
+ "startOffsets": "3852,12771,12824,12877,12930,114381,114557,114679,114941,115136",
+ "endColumns": "88,52,52,52,52,65,121,60,65,66",
+ "endOffsets": "3936,12819,12872,12925,12978,114442,114674,114735,115002,115198"
+ }
+ },
+ {
+ "source": "E:\\Note\\src\\app\\src\\main\\res\\values\\styles.xml",
+ "from": {
+ "startLines": "50,55,64,60,22,26,30,35,40,18,45",
+ "startColumns": "4,4,4,4,4,4,4,4,4,4,4",
+ "startOffsets": "2112,2322,2704,2539,917,1104,1293,1484,1693,730,1905",
+ "endLines": "53,58,66,62,25,29,33,38,43,21,48",
+ "endColumns": "12,12,12,12,12,12,12,12,12,12,12",
+ "endOffsets": "2314,2531,2865,2696,1098,1287,1476,1685,1897,911,2104"
+ },
+ "to": {
+ "startLines": "1453,1457,1461,1464,1738,1742,1746,1750,1754,1758,1762",
+ "startColumns": "4,4,4,4,4,4,4,4,4,4,4",
+ "startOffsets": "94127,94331,94542,94706,115631,115814,115999,116184,116387,116593,116776",
+ "endLines": "1456,1460,1463,1466,1741,1745,1749,1753,1757,1761,1765",
+ "endColumns": "12,12,12,12,12,12,12,12,12,12,12",
+ "endOffsets": "94326,94537,94701,94861,115809,115994,116179,116382,116588,116771,116972"
+ }
+ },
+ {
+ "source": "E:\\Note\\src\\app\\src\\main\\res\\values\\dimens.xml",
+ "from": {
+ "startLines": "19,20,21,22,18",
+ "startColumns": "4,4,4,4,4",
+ "startOffsets": "783,836,890,944,730",
+ "endColumns": "51,52,52,51,51",
+ "endOffsets": "830,884,938,991,777"
+ },
+ "to": {
+ "startLines": "194,195,196,197,198",
+ "startColumns": "4,4,4,4,4",
+ "startOffsets": "12983,13035,13088,13141,13193",
+ "endColumns": "51,52,52,51,51",
+ "endOffsets": "13030,13083,13136,13188,13240"
+ }
+ },
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\df8a19ef163eaa8f3d3c8f24458897fd\\coordinatorlayout-1.0.0\\res\\values\\values.xml",
+ "from": {
+ "startLines": "2,102,3,13",
+ "startColumns": "4,4,4,4",
+ "startOffsets": "55,5935,116,724",
+ "endLines": "2,104,12,101",
+ "endColumns": "60,12,24,24",
+ "endOffsets": "111,6075,719,5930"
+ },
+ "to": {
+ "startLines": "12,1898,2544,2554",
+ "startColumns": "4,4,4,4",
+ "startOffsets": "532,127514,162250,162858",
+ "endLines": "12,1900,2553,2642",
+ "endColumns": "60,12,24,24",
+ "endOffsets": "588,127654,162853,168064"
+ }
+ },
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\6d11613c3b6a00a9ea456b5609ec43f7\\core-1.0.0\\res\\values\\values.xml",
+ "from": {
+ "startLines": "2,3,132,133,134,135,136,137,138,139,140,141,142,143,144,145,146,147,148,149,150,151,152,153,154,155,156,157,158,159,160,161,162,163,164,165,166,167,171,172,176,177,178,13,56,88,125",
+ "startColumns": "4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4",
+ "startOffsets": "55,124,7725,7795,7863,7935,8005,8066,8140,8213,8274,8335,8397,8461,8523,8584,8652,8752,8812,8878,8951,9020,9077,9129,9191,9263,9339,9374,9409,9459,9520,9577,9611,9646,9681,9751,9822,9939,10140,10250,10451,10580,10652,617,3523,5588,7348",
+ "endLines": "2,3,132,133,134,135,136,137,138,139,140,141,142,143,144,145,146,147,148,149,150,151,152,153,154,155,156,157,158,159,160,161,162,163,164,165,166,170,171,175,176,177,178,55,87,124,131",
+ "endColumns": "68,62,69,67,71,69,60,73,72,60,60,61,63,61,60,67,99,59,65,72,68,56,51,61,71,75,34,34,49,60,56,33,34,34,69,70,116,12,109,12,128,71,66,24,24,24,24",
+ "endOffsets": "119,182,7790,7858,7930,8000,8061,8135,8208,8269,8330,8392,8456,8518,8579,8647,8747,8807,8873,8946,9015,9072,9124,9186,9258,9334,9369,9404,9454,9515,9572,9606,9641,9676,9746,9817,9934,10135,10245,10446,10575,10647,10714,3518,5583,7343,7720"
+ },
+ "to": {
+ "startLines": "60,61,159,160,161,162,163,164,165,175,176,177,178,179,180,181,182,183,184,185,186,187,188,189,207,208,214,215,219,220,221,222,223,224,230,375,1716,1717,1722,1725,1730,1896,1897,2661,2704,2736,2773",
+ "startColumns": "4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4",
+ "startOffsets": "3720,3789,10521,10591,10659,10731,10801,10862,10936,11793,11854,11915,11977,12041,12103,12164,12232,12332,12392,12458,12531,12600,12657,12709,13698,13770,14085,14120,14297,14347,14408,14465,14499,14534,14844,24804,114063,114180,114447,114740,115007,127375,127447,169102,172008,174073,175833",
+ "endLines": "60,61,159,160,161,162,163,164,165,175,176,177,178,179,180,181,182,183,184,185,186,187,188,189,207,208,214,215,219,220,221,222,223,224,230,375,1716,1720,1722,1728,1730,1896,1897,2703,2735,2772,2779",
+ "endColumns": "68,62,69,67,71,69,60,73,72,60,60,61,63,61,60,67,99,59,65,72,68,56,51,61,71,75,34,34,49,60,56,33,34,34,69,70,116,12,109,12,128,71,66,24,24,24,24",
+ "endOffsets": "3784,3847,10586,10654,10726,10796,10857,10931,11004,11849,11910,11972,12036,12098,12159,12227,12327,12387,12453,12526,12595,12652,12704,12766,13765,13841,14115,14150,14342,14403,14460,14494,14529,14564,14909,24870,114175,114376,114552,114936,115131,127442,127509,172003,174068,175828,176205"
+ }
+ },
+ {
+ "source": "E:\\Note\\src\\app\\src\\main\\res\\values\\strings.xml",
+ "from": {
+ "startLines": "138,82,85,84,83,29,30,31,128,129,23,137,136,27,36,22,25,91,92,90,89,88,104,103,102,94,49,48,74,39,40,95,51,86,130,81,21,19,77,20,52,58,63,53,73,72,71,67,66,64,65,68,69,59,80,70,78,57,62,61,60,76,56,75,54,55,79,38,44,46,43,45,42,41,35,34,111,110,114,126,119,118,120,121,123,122,112,113,117,115,116,109,124,125,135,133,132,134,26,37,93,101,106,105,107,24,100,99,98,97,32,33",
+ "startColumns": "4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4",
+ "startOffsets": "8684,4518,4782,4685,4615,1394,1438,1491,8172,8222,1121,8625,8573,1321,1856,1054,1223,5242,5337,5170,5085,5001,6216,6132,6029,5515,2591,2539,4009,2063,2117,5577,2686,4866,8286,4446,987,846,4197,908,2746,3067,3373,2805,3937,3875,3817,3591,3538,3433,3487,3642,3693,3115,4379,3754,4247,3019,3317,3228,3169,4134,2968,4088,2863,2907,4311,2007,2332,2442,2284,2388,2227,2178,1800,1746,6679,6611,6923,8073,7292,7210,7367,7457,7701,7621,6764,6840,7150,6988,7069,6555,7846,7969,8531,8402,8344,8456,1268,1941,5446,5942,6353,6283,6434,1172,5882,5826,5763,5702,1544,1655",
+ "endLines": "142,82,85,84,83,29,30,31,128,129,23,137,136,27,36,22,25,91,92,90,89,88,104,103,102,94,49,48,74,39,40,95,51,86,130,81,21,19,77,20,52,58,63,53,73,72,71,67,66,64,65,68,69,59,80,70,78,57,62,61,60,76,56,75,54,55,79,38,44,46,43,45,42,41,35,34,111,110,114,126,119,118,120,121,123,122,112,113,117,115,116,109,124,125,135,133,132,134,26,37,93,101,106,105,107,24,100,99,98,97,32,33",
+ "endColumns": "14,95,82,95,68,42,51,51,48,62,49,57,50,69,83,65,43,93,107,70,83,82,65,82,101,60,61,50,77,52,59,104,58,101,54,70,65,60,48,77,57,46,58,56,70,60,56,49,51,52,49,49,59,52,65,61,62,46,54,87,57,61,49,44,42,59,66,54,54,52,46,52,55,47,54,52,83,66,63,95,73,80,88,162,143,78,74,81,58,79,79,54,121,102,40,52,56,73,51,64,67,85,79,68,93,49,58,54,61,59,109,89",
+ "endOffsets": "9092,4609,4860,4776,4679,1432,1485,1538,8216,8280,1166,8678,8619,1386,1935,1115,1262,5331,5440,5236,5164,5079,6277,6210,6126,5571,2648,2585,4082,2111,2172,5677,2740,4963,8336,4512,1048,902,4241,981,2799,3109,3427,2857,4003,3931,3869,3636,3585,3481,3532,3687,3748,3163,4440,3811,4305,3061,3367,3311,3222,4191,3013,4128,2901,2962,4373,2057,2382,2490,2326,2436,2278,2221,1850,1794,6758,6673,6982,8164,7361,7286,7451,7615,7840,7695,6834,6917,7204,7063,7144,6605,7963,8067,8567,8450,8396,8525,1315,2001,5509,6023,6428,6347,6523,1217,5936,5876,5820,5757,1649,1740"
+ },
+ "to": {
+ "startLines": "231,275,276,277,278,279,280,281,282,283,284,285,286,287,288,289,290,291,292,293,294,295,296,297,298,299,300,301,302,303,304,305,306,307,308,309,310,311,312,313,314,315,316,317,318,319,320,321,322,323,324,325,326,327,328,329,330,331,332,333,334,335,336,337,338,339,340,341,342,343,344,345,346,347,348,349,350,351,352,353,354,355,356,357,358,359,360,361,362,363,364,365,366,367,368,369,370,372,373,374,376,377,378,379,380,381,382,383,384,385,386,387",
+ "startColumns": "4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4",
+ "startOffsets": "14914,18065,18161,18244,18340,18409,18452,18504,18556,18605,18668,18718,18776,18827,18897,18981,19047,19091,19185,19293,19364,19448,19531,19597,19680,19782,19843,19905,19956,20034,20087,20147,20252,20311,20413,20468,20539,20605,20666,20715,20793,20851,20898,20957,21014,21085,21146,21203,21253,21305,21358,21408,21458,21518,21571,21637,21699,21762,21809,21864,21952,22010,22072,22122,22167,22210,22270,22337,22392,22447,22500,22547,22600,22656,22704,22759,22812,22896,22963,23027,23123,23197,23278,23367,23530,23674,23753,23828,23910,23969,24049,24129,24184,24306,24409,24450,24503,24613,24687,24739,24875,24943,25029,25109,25178,25272,25322,25381,25436,25498,25558,25668",
+ "endLines": "235,275,276,277,278,279,280,281,282,283,284,285,286,287,288,289,290,291,292,293,294,295,296,297,298,299,300,301,302,303,304,305,306,307,308,309,310,311,312,313,314,315,316,317,318,319,320,321,322,323,324,325,326,327,328,329,330,331,332,333,334,335,336,337,338,339,340,341,342,343,344,345,346,347,348,349,350,351,352,353,354,355,356,357,358,359,360,361,362,363,364,365,366,367,368,369,370,372,373,374,376,377,378,379,380,381,382,383,384,385,386,387",
+ "endColumns": "14,95,82,95,68,42,51,51,48,62,49,57,50,69,83,65,43,93,107,70,83,82,65,82,101,60,61,50,77,52,59,104,58,101,54,70,65,60,48,77,57,46,58,56,70,60,56,49,51,52,49,49,59,52,65,61,62,46,54,87,57,61,49,44,42,59,66,54,54,52,46,52,55,47,54,52,83,66,63,95,73,80,88,162,143,78,74,81,58,79,79,54,121,102,40,52,56,73,51,64,67,85,79,68,93,49,58,54,61,59,109,89",
+ "endOffsets": "15302,18156,18239,18335,18404,18447,18499,18551,18600,18663,18713,18771,18822,18892,18976,19042,19086,19180,19288,19359,19443,19526,19592,19675,19777,19838,19900,19951,20029,20082,20142,20247,20306,20408,20463,20534,20600,20661,20710,20788,20846,20893,20952,21009,21080,21141,21198,21248,21300,21353,21403,21453,21513,21566,21632,21694,21757,21804,21859,21947,22005,22067,22117,22162,22205,22265,22332,22387,22442,22495,22542,22595,22651,22699,22754,22807,22891,22958,23022,23118,23192,23273,23362,23525,23669,23748,23823,23905,23964,24044,24124,24179,24301,24404,24445,24498,24555,24682,24734,24799,24938,25024,25104,25173,25267,25317,25376,25431,25493,25553,25663,25753"
+ }
+ }
+ ]
+ },
+ {
+ "outputFile": "E:\\Note\\src\\app\\build\\intermediates\\res\\merged\\debug\\values-v28_values-v28.arsc.flat",
+ "map": [
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\88c548461109b0c917067cfea58751b3\\appcompat-1.0.0-alpha1\\res\\values-v28\\values-v28.xml",
+ "from": {
+ "startLines": "2,3,4,8",
+ "startColumns": "4,4,4,4",
+ "startOffsets": "55,130,217,447",
+ "endLines": "2,3,7,11",
+ "endColumns": "74,86,12,12",
+ "endOffsets": "125,212,442,684"
+ }
+ }
+ ]
+ },
+ {
+ "outputFile": "E:\\Note\\src\\app\\build\\intermediates\\res\\merged\\debug\\values-bn_values-bn.arsc.flat",
+ "map": [
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\88c548461109b0c917067cfea58751b3\\appcompat-1.0.0-alpha1\\res\\values-bn\\values-bn.xml",
+ "from": {
+ "startLines": "2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19,20,21,22,23,24,25,26,27,28,29",
+ "startColumns": "4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4",
+ "startOffsets": "105,214,326,432,526,631,760,838,916,1007,1100,1195,1289,1390,1483,1578,1672,1763,1854,1941,2051,2159,2258,2368,2474,2587,2752,2857",
+ "endColumns": "108,111,105,93,104,128,77,77,90,92,94,93,100,92,94,93,90,90,86,109,107,98,109,105,112,164,104,81",
+ "endOffsets": "209,321,427,521,626,755,833,911,1002,1095,1190,1284,1385,1478,1573,1667,1758,1849,1936,2046,2154,2253,2363,2469,2582,2747,2852,2934"
+ }
+ },
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\6d11613c3b6a00a9ea456b5609ec43f7\\core-1.0.0\\res\\values-bn\\values-bn.xml",
+ "from": {
+ "startLines": "2",
+ "startColumns": "4",
+ "startOffsets": "55",
+ "endColumns": "100",
+ "endOffsets": "151"
+ },
+ "to": {
+ "startLines": "30",
+ "startColumns": "4",
+ "startOffsets": "2939",
+ "endColumns": "100",
+ "endOffsets": "3035"
+ }
+ }
+ ]
+ },
+ {
+ "outputFile": "E:\\Note\\src\\app\\build\\intermediates\\res\\merged\\debug\\values-ur_values-ur.arsc.flat",
+ "map": [
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\88c548461109b0c917067cfea58751b3\\appcompat-1.0.0-alpha1\\res\\values-ur\\values-ur.xml",
+ "from": {
+ "startLines": "2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19,20,21,22,23,24,25,26,27,28,29",
+ "startColumns": "4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4",
+ "startOffsets": "105,215,321,430,516,620,740,816,892,984,1078,1174,1268,1370,1464,1560,1654,1746,1838,1923,2031,2140,2242,2353,2453,2561,2726,2824",
+ "endColumns": "109,105,108,85,103,119,75,75,91,93,95,93,101,93,95,93,91,91,84,107,108,101,110,99,107,164,97,79",
+ "endOffsets": "210,316,425,511,615,735,811,887,979,1073,1169,1263,1365,1459,1555,1649,1741,1833,1918,2026,2135,2237,2348,2448,2556,2721,2819,2899"
+ }
+ },
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\6d11613c3b6a00a9ea456b5609ec43f7\\core-1.0.0\\res\\values-ur\\values-ur.xml",
+ "from": {
+ "startLines": "2",
+ "startColumns": "4",
+ "startOffsets": "55",
+ "endColumns": "100",
+ "endOffsets": "151"
+ },
+ "to": {
+ "startLines": "30",
+ "startColumns": "4",
+ "startOffsets": "2904",
+ "endColumns": "100",
+ "endOffsets": "3000"
+ }
+ }
+ ]
+ },
+ {
+ "outputFile": "E:\\Note\\src\\app\\build\\intermediates\\res\\merged\\debug\\values-sr_values-sr.arsc.flat",
+ "map": [
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\6d11613c3b6a00a9ea456b5609ec43f7\\core-1.0.0\\res\\values-sr\\values-sr.xml",
+ "from": {
+ "startLines": "2",
+ "startColumns": "4",
+ "startOffsets": "55",
+ "endColumns": "100",
+ "endOffsets": "151"
+ },
+ "to": {
+ "startLines": "30",
+ "startColumns": "4",
+ "startOffsets": "2905",
+ "endColumns": "100",
+ "endOffsets": "3001"
+ }
+ },
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\88c548461109b0c917067cfea58751b3\\appcompat-1.0.0-alpha1\\res\\values-sr\\values-sr.xml",
+ "from": {
+ "startLines": "2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19,20,21,22,23,24,25,26,27,28,29",
+ "startColumns": "4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4",
+ "startOffsets": "105,214,317,423,509,613,731,812,892,983,1076,1172,1266,1367,1460,1555,1660,1751,1842,1930,2035,2143,2244,2348,2456,2557,2724,2821",
+ "endColumns": "108,102,105,85,103,117,80,79,90,92,95,93,100,92,94,104,90,90,87,104,107,100,103,107,100,166,96,83",
+ "endOffsets": "209,312,418,504,608,726,807,887,978,1071,1167,1261,1362,1455,1550,1655,1746,1837,1925,2030,2138,2239,2343,2451,2552,2719,2816,2900"
+ }
+ }
+ ]
+ },
+ {
+ "outputFile": "E:\\Note\\src\\app\\build\\intermediates\\res\\merged\\debug\\values-el_values-el.arsc.flat",
+ "map": [
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\88c548461109b0c917067cfea58751b3\\appcompat-1.0.0-alpha1\\res\\values-el\\values-el.xml",
+ "from": {
+ "startLines": "2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19,20,21,22,23,24,25,26,27,28,29",
+ "startColumns": "4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4",
+ "startOffsets": "105,223,334,451,536,641,767,855,941,1032,1125,1221,1315,1416,1509,1604,1701,1792,1883,1968,2079,2189,2291,2402,2511,2619,2779,2879",
+ "endColumns": "117,110,116,84,104,125,87,85,90,92,95,93,100,92,94,96,90,90,84,110,109,101,110,108,107,159,99,84",
+ "endOffsets": "218,329,446,531,636,762,850,936,1027,1120,1216,1310,1411,1504,1599,1696,1787,1878,1963,2074,2184,2286,2397,2506,2614,2774,2874,2959"
+ }
+ },
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\6d11613c3b6a00a9ea456b5609ec43f7\\core-1.0.0\\res\\values-el\\values-el.xml",
+ "from": {
+ "startLines": "2",
+ "startColumns": "4",
+ "startOffsets": "55",
+ "endColumns": "100",
+ "endOffsets": "151"
+ },
+ "to": {
+ "startLines": "30",
+ "startColumns": "4",
+ "startOffsets": "2964",
+ "endColumns": "100",
+ "endOffsets": "3060"
+ }
+ }
+ ]
+ },
+ {
+ "outputFile": "E:\\Note\\src\\app\\build\\intermediates\\res\\merged\\debug\\values-ne_values-ne.arsc.flat",
+ "map": [
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\88c548461109b0c917067cfea58751b3\\appcompat-1.0.0-alpha1\\res\\values-ne\\values-ne.xml",
+ "from": {
+ "startLines": "2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19,20,21,22,23,24,25,26,27,28,29",
+ "startColumns": "4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4",
+ "startOffsets": "105,210,314,422,513,620,747,841,931,1022,1115,1211,1305,1406,1499,1594,1688,1779,1870,1958,2068,2184,2287,2402,2504,2619,2790,2902",
+ "endColumns": "104,103,107,90,106,126,93,89,90,92,95,93,100,92,94,93,90,90,87,109,115,102,114,101,114,170,111,85",
+ "endOffsets": "205,309,417,508,615,742,836,926,1017,1110,1206,1300,1401,1494,1589,1683,1774,1865,1953,2063,2179,2282,2397,2499,2614,2785,2897,2983"
+ }
+ },
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\6d11613c3b6a00a9ea456b5609ec43f7\\core-1.0.0\\res\\values-ne\\values-ne.xml",
+ "from": {
+ "startLines": "2",
+ "startColumns": "4",
+ "startOffsets": "55",
+ "endColumns": "100",
+ "endOffsets": "151"
+ },
+ "to": {
+ "startLines": "30",
+ "startColumns": "4",
+ "startOffsets": "2988",
+ "endColumns": "100",
+ "endOffsets": "3084"
+ }
+ }
+ ]
+ },
+ {
+ "outputFile": "E:\\Note\\src\\app\\build\\intermediates\\res\\merged\\debug\\values-ml_values-ml.arsc.flat",
+ "map": [
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\6d11613c3b6a00a9ea456b5609ec43f7\\core-1.0.0\\res\\values-ml\\values-ml.xml",
+ "from": {
+ "startLines": "2",
+ "startColumns": "4",
+ "startOffsets": "55",
+ "endColumns": "100",
+ "endOffsets": "151"
+ },
+ "to": {
+ "startLines": "30",
+ "startColumns": "4",
+ "startOffsets": "2955",
+ "endColumns": "100",
+ "endOffsets": "3051"
+ }
+ },
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\88c548461109b0c917067cfea58751b3\\appcompat-1.0.0-alpha1\\res\\values-ml\\values-ml.xml",
+ "from": {
+ "startLines": "2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19,20,21,22,23,24,25,26,27,28,29",
+ "startColumns": "4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4",
+ "startOffsets": "105,224,342,457,550,655,787,864,940,1031,1124,1226,1320,1421,1515,1610,1709,1800,1891,1973,2084,2190,2288,2402,2502,2613,2772,2873",
+ "endColumns": "118,117,114,92,104,131,76,75,90,92,101,93,100,93,94,98,90,90,81,110,105,97,113,99,110,158,100,81",
+ "endOffsets": "219,337,452,545,650,782,859,935,1026,1119,1221,1315,1416,1510,1605,1704,1795,1886,1968,2079,2185,2283,2397,2497,2608,2767,2868,2950"
+ }
+ }
+ ]
+ },
+ {
+ "outputFile": "E:\\Note\\src\\app\\build\\intermediates\\res\\merged\\debug\\values-mr_values-mr.arsc.flat",
+ "map": [
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\88c548461109b0c917067cfea58751b3\\appcompat-1.0.0-alpha1\\res\\values-mr\\values-mr.xml",
+ "from": {
+ "startLines": "2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19,20,21,22,23,24,25,26,27,28,29",
+ "startColumns": "4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4",
+ "startOffsets": "105,216,322,429,519,620,735,812,890,981,1074,1168,1265,1366,1459,1554,1651,1742,1833,1913,2025,2127,2223,2332,2433,2545,2702,2807",
+ "endColumns": "110,105,106,89,100,114,76,77,90,92,93,96,100,92,94,96,90,90,79,111,101,95,108,100,111,156,104,79",
+ "endOffsets": "211,317,424,514,615,730,807,885,976,1069,1163,1260,1361,1454,1549,1646,1737,1828,1908,2020,2122,2218,2327,2428,2540,2697,2802,2882"
+ }
+ },
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\6d11613c3b6a00a9ea456b5609ec43f7\\core-1.0.0\\res\\values-mr\\values-mr.xml",
+ "from": {
+ "startLines": "2",
+ "startColumns": "4",
+ "startOffsets": "55",
+ "endColumns": "100",
+ "endOffsets": "151"
+ },
+ "to": {
+ "startLines": "30",
+ "startColumns": "4",
+ "startOffsets": "2887",
+ "endColumns": "100",
+ "endOffsets": "2983"
+ }
+ }
+ ]
+ },
+ {
+ "outputFile": "E:\\Note\\src\\app\\build\\intermediates\\res\\merged\\debug\\values-hi_values-hi.arsc.flat",
+ "map": [
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\88c548461109b0c917067cfea58751b3\\appcompat-1.0.0-alpha1\\res\\values-hi\\values-hi.xml",
+ "from": {
+ "startLines": "2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19,20,21,22,23,24,25,26,27,28,29",
+ "startColumns": "4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4",
+ "startOffsets": "105,211,308,418,504,606,728,805,883,974,1067,1163,1257,1358,1451,1546,1640,1731,1822,1912,2021,2124,2226,2336,2437,2549,2711,2812",
+ "endColumns": "105,96,109,85,101,121,76,77,90,92,95,93,100,92,94,93,90,90,89,108,102,101,109,100,111,161,100,79",
+ "endOffsets": "206,303,413,499,601,723,800,878,969,1062,1158,1252,1353,1446,1541,1635,1726,1817,1907,2016,2119,2221,2331,2432,2544,2706,2807,2887"
+ }
+ },
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\6d11613c3b6a00a9ea456b5609ec43f7\\core-1.0.0\\res\\values-hi\\values-hi.xml",
+ "from": {
+ "startLines": "2",
+ "startColumns": "4",
+ "startOffsets": "55",
+ "endColumns": "100",
+ "endOffsets": "151"
+ },
+ "to": {
+ "startLines": "30",
+ "startColumns": "4",
+ "startOffsets": "2892",
+ "endColumns": "100",
+ "endOffsets": "2988"
+ }
+ }
+ ]
+ },
+ {
+ "outputFile": "E:\\Note\\src\\app\\build\\intermediates\\res\\merged\\debug\\values-pa_values-pa.arsc.flat",
+ "map": [
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\6d11613c3b6a00a9ea456b5609ec43f7\\core-1.0.0\\res\\values-pa\\values-pa.xml",
+ "from": {
+ "startLines": "2",
+ "startColumns": "4",
+ "startOffsets": "55",
+ "endColumns": "100",
+ "endOffsets": "151"
+ },
+ "to": {
+ "startLines": "30",
+ "startColumns": "4",
+ "startOffsets": "2839",
+ "endColumns": "100",
+ "endOffsets": "2935"
+ }
+ },
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\88c548461109b0c917067cfea58751b3\\appcompat-1.0.0-alpha1\\res\\values-pa\\values-pa.xml",
+ "from": {
+ "startLines": "2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19,20,21,22,23,24,25,26,27,28,29",
+ "startColumns": "4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4",
+ "startOffsets": "105,208,305,410,496,596,709,786,862,953,1046,1142,1236,1337,1430,1525,1619,1710,1801,1880,1981,2085,2182,2291,2390,2500,2659,2759",
+ "endColumns": "102,96,104,85,99,112,76,75,90,92,95,93,100,92,94,93,90,90,78,100,103,96,108,98,109,158,99,79",
+ "endOffsets": "203,300,405,491,591,704,781,857,948,1041,1137,1231,1332,1425,1520,1614,1705,1796,1875,1976,2080,2177,2286,2385,2495,2654,2754,2834"
+ }
+ }
+ ]
+ },
+ {
+ "outputFile": "E:\\Note\\src\\app\\build\\intermediates\\res\\merged\\debug\\values-zh-rCN_values-zh-rCN.arsc.flat",
+ "map": [
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\6d11613c3b6a00a9ea456b5609ec43f7\\core-1.0.0\\res\\values-zh-rCN\\values-zh-rCN.xml",
+ "from": {
+ "startLines": "2",
+ "startColumns": "4",
+ "startOffsets": "55",
+ "endColumns": "100",
+ "endOffsets": "151"
+ },
+ "to": {
+ "startLines": "132",
+ "startColumns": "4",
+ "startOffsets": "8392",
+ "endColumns": "100",
+ "endOffsets": "8488"
+ }
+ },
+ {
+ "source": "E:\\Note\\src\\app\\src\\main\\res\\values-zh-rCN\\arrays.xml",
+ "from": {
+ "startLines": "18",
+ "startColumns": "4",
+ "startOffsets": "730",
+ "endLines": "21",
+ "endColumns": "19",
+ "endOffsets": "838"
+ },
+ "to": {
+ "startLines": "2",
+ "startColumns": "4",
+ "startOffsets": "105",
+ "endLines": "5",
+ "endColumns": "19",
+ "endOffsets": "210"
+ }
+ },
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\88c548461109b0c917067cfea58751b3\\appcompat-1.0.0-alpha1\\res\\values-zh-rCN\\values-zh-rCN.xml",
+ "from": {
+ "startLines": "2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19,20,21,22,23,24,25,26,27,28,29",
+ "startColumns": "4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4",
+ "startOffsets": "105,201,296,396,478,575,681,757,833,924,1017,1115,1211,1306,1399,1494,1586,1677,1768,1846,1942,2038,2133,2230,2325,2423,2572,2666",
+ "endColumns": "95,94,99,81,96,105,75,75,90,92,97,95,94,92,94,91,90,90,77,95,95,94,96,94,97,148,93,77",
+ "endOffsets": "196,291,391,473,570,676,752,828,919,1012,1110,1206,1301,1394,1489,1581,1672,1763,1841,1937,2033,2128,2225,2320,2418,2567,2661,2739"
+ },
+ "to": {
+ "startLines": "9,10,11,12,13,14,15,16,17,18,19,20,21,22,23,24,25,26,27,28,29,30,31,32,33,34,35,128",
+ "startColumns": "4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4",
+ "startOffsets": "384,480,575,675,757,854,960,1036,1112,1203,1296,1394,1490,1585,1678,1773,1865,1956,2047,2125,2221,2317,2412,2509,2604,2702,2851,8147",
+ "endColumns": "95,94,99,81,96,105,75,75,90,92,97,95,94,92,94,91,90,90,77,95,95,94,96,94,97,148,93,77",
+ "endOffsets": "475,570,670,752,849,955,1031,1107,1198,1291,1389,1485,1580,1673,1768,1860,1951,2042,2120,2216,2312,2407,2504,2599,2697,2846,2940,8220"
+ }
+ },
+ {
+ "source": "E:\\Note\\src\\app\\src\\main\\res\\values-zh-rCN\\strings.xml",
+ "from": {
+ "startLines": "134,84,83,82,81,32,33,34,125,126,25,133,132,29,39,24,27,90,91,89,88,87,103,102,101,93,73,42,43,94,85,127,80,23,21,76,22,51,57,62,52,72,71,70,66,65,63,64,67,68,58,79,69,77,56,61,60,59,75,55,74,53,54,78,41,47,49,46,48,45,44,38,37,110,109,112,124,117,116,118,119,121,120,111,115,113,114,108,122,123,131,129,128,130,28,40,92,100,105,104,106,26,99,98,97,96,35,36",
+ "startColumns": "4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4",
+ "startOffsets": "7171,4084,4017,3943,3892,1364,1405,1454,6713,6759,1101,7116,7065,1273,1743,1049,1187,4456,4525,4396,4330,4266,5200,5139,5075,4659,3455,1916,1970,4714,4158,6817,3832,995,885,3615,938,2354,2641,2892,2408,3394,3340,3288,3089,3040,2944,2993,3136,3184,2685,3772,3235,3659,2597,2844,2787,2731,3559,2552,3516,2459,2501,3712,1864,2175,2273,2127,2225,2079,2033,1691,1637,5582,5522,5725,6638,6041,5971,6106,6185,6370,6296,5658,5915,5783,5849,5472,6475,6559,7026,6917,6868,6963,1224,1806,4603,5015,5315,5256,5383,1142,4966,4920,4871,4819,1503,1570",
+ "endLines": "136,84,83,82,81,32,33,34,125,126,25,133,132,29,39,24,27,90,91,89,88,87,103,102,101,93,73,42,43,94,85,127,80,23,21,76,22,51,57,62,52,72,71,70,66,65,63,64,67,68,58,79,69,77,56,61,60,59,75,55,74,53,54,78,41,47,49,46,48,45,44,38,37,110,109,112,124,117,116,118,119,121,120,111,115,113,114,108,122,123,131,129,128,130,28,40,92,100,105,104,106,26,99,98,97,96,35,36",
+ "endColumns": "14,72,65,72,49,39,47,47,44,56,39,53,49,50,61,50,35,67,76,58,64,62,54,59,62,53,59,52,61,84,80,49,58,52,51,42,55,52,42,50,49,59,52,50,45,47,47,45,46,49,44,58,51,51,42,46,55,54,54,43,41,40,49,58,50,48,48,46,46,46,44,50,52,74,58,56,73,63,68,77,109,103,72,65,54,64,64,48,82,77,37,44,47,61,47,56,54,58,66,57,61,43,47,44,47,50,65,65",
+ "endOffsets": "7345,4152,4078,4011,3937,1399,1448,1497,6753,6811,1136,7165,7110,1319,1800,1095,1218,4519,4597,4450,4390,4324,5250,5194,5133,4708,3510,1964,2027,4794,4234,6862,3886,1043,932,3653,989,2402,2679,2938,2453,3449,3388,3334,3130,3083,2987,3034,3178,3229,2725,3826,3282,3706,2635,2886,2838,2781,3609,2591,3553,2495,2546,3766,1910,2219,2317,2169,2267,2121,2073,1737,1685,5652,5576,5777,6707,6100,6035,6179,6290,6469,6364,5719,5965,5843,5909,5516,6553,6632,7059,6957,6911,7020,1267,1858,4653,5069,5377,5309,5440,1181,5009,4960,4914,4865,1564,1631"
+ },
+ "to": {
+ "startLines": "6,36,37,38,39,40,41,42,43,44,45,46,47,48,49,50,51,52,53,54,55,56,57,58,59,60,61,62,63,64,65,66,67,68,69,70,71,72,73,74,75,76,77,78,79,80,81,82,83,84,85,86,87,88,89,90,91,92,93,94,95,96,97,98,99,100,101,102,103,104,105,106,107,108,109,110,111,112,113,114,115,116,117,118,119,120,121,122,123,124,125,126,127,129,130,131,133,134,135,136,137,138,139,140,141,142,143,144",
+ "startColumns": "4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4",
+ "startOffsets": "215,2945,3018,3084,3157,3207,3247,3295,3343,3388,3445,3485,3539,3589,3640,3702,3753,3789,3857,3934,3993,4058,4121,4176,4236,4299,4353,4413,4466,4528,4613,4694,4744,4803,4856,4908,4951,5007,5060,5103,5154,5204,5264,5317,5368,5414,5462,5510,5556,5603,5653,5698,5757,5809,5861,5904,5951,6007,6062,6117,6161,6203,6244,6294,6353,6404,6453,6502,6549,6596,6643,6688,6739,6792,6867,6926,6983,7057,7121,7190,7268,7378,7482,7555,7621,7676,7741,7806,7855,7938,8016,8054,8099,8225,8287,8335,8493,8548,8607,8674,8732,8794,8838,8886,8931,8979,9030,9096",
+ "endLines": "8,36,37,38,39,40,41,42,43,44,45,46,47,48,49,50,51,52,53,54,55,56,57,58,59,60,61,62,63,64,65,66,67,68,69,70,71,72,73,74,75,76,77,78,79,80,81,82,83,84,85,86,87,88,89,90,91,92,93,94,95,96,97,98,99,100,101,102,103,104,105,106,107,108,109,110,111,112,113,114,115,116,117,118,119,120,121,122,123,124,125,126,127,129,130,131,133,134,135,136,137,138,139,140,141,142,143,144",
+ "endColumns": "14,72,65,72,49,39,47,47,44,56,39,53,49,50,61,50,35,67,76,58,64,62,54,59,62,53,59,52,61,84,80,49,58,52,51,42,55,52,42,50,49,59,52,50,45,47,47,45,46,49,44,58,51,51,42,46,55,54,54,43,41,40,49,58,50,48,48,46,46,46,44,50,52,74,58,56,73,63,68,77,109,103,72,65,54,64,64,48,82,77,37,44,47,61,47,56,54,58,66,57,61,43,47,44,47,50,65,65",
+ "endOffsets": "379,3013,3079,3152,3202,3242,3290,3338,3383,3440,3480,3534,3584,3635,3697,3748,3784,3852,3929,3988,4053,4116,4171,4231,4294,4348,4408,4461,4523,4608,4689,4739,4798,4851,4903,4946,5002,5055,5098,5149,5199,5259,5312,5363,5409,5457,5505,5551,5598,5648,5693,5752,5804,5856,5899,5946,6002,6057,6112,6156,6198,6239,6289,6348,6399,6448,6497,6544,6591,6638,6683,6734,6787,6862,6921,6978,7052,7116,7185,7263,7373,7477,7550,7616,7671,7736,7801,7850,7933,8011,8049,8094,8142,8282,8330,8387,8543,8602,8669,8727,8789,8833,8881,8926,8974,9025,9091,9157"
+ }
+ }
+ ]
+ },
+ {
+ "outputFile": "E:\\Note\\src\\app\\build\\intermediates\\res\\merged\\debug\\values-gl_values-gl.arsc.flat",
+ "map": [
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\6d11613c3b6a00a9ea456b5609ec43f7\\core-1.0.0\\res\\values-gl\\values-gl.xml",
+ "from": {
+ "startLines": "2",
+ "startColumns": "4",
+ "startOffsets": "55",
+ "endColumns": "100",
+ "endOffsets": "151"
+ },
+ "to": {
+ "startLines": "30",
+ "startColumns": "4",
+ "startOffsets": "2920",
+ "endColumns": "100",
+ "endOffsets": "3016"
+ }
+ },
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\88c548461109b0c917067cfea58751b3\\appcompat-1.0.0-alpha1\\res\\values-gl\\values-gl.xml",
+ "from": {
+ "startLines": "2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19,20,21,22,23,24,25,26,27,28,29",
+ "startColumns": "4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4",
+ "startOffsets": "105,217,329,437,522,624,750,834,915,1007,1101,1199,1293,1394,1488,1584,1679,1771,1863,1945,2052,2161,2260,2368,2472,2579,2738,2838",
+ "endColumns": "111,111,107,84,101,125,83,80,91,93,97,93,100,93,95,94,91,91,81,106,108,98,107,103,106,158,99,81",
+ "endOffsets": "212,324,432,517,619,745,829,910,1002,1096,1194,1288,1389,1483,1579,1674,1766,1858,1940,2047,2156,2255,2363,2467,2574,2733,2833,2915"
+ }
+ }
+ ]
+ },
+ {
+ "outputFile": "E:\\Note\\src\\app\\build\\intermediates\\res\\merged\\debug\\values-gu_values-gu.arsc.flat",
+ "map": [
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\6d11613c3b6a00a9ea456b5609ec43f7\\core-1.0.0\\res\\values-gu\\values-gu.xml",
+ "from": {
+ "startLines": "2",
+ "startColumns": "4",
+ "startOffsets": "55",
+ "endColumns": "100",
+ "endOffsets": "151"
+ },
+ "to": {
+ "startLines": "30",
+ "startColumns": "4",
+ "startOffsets": "2882",
+ "endColumns": "100",
+ "endOffsets": "2978"
+ }
+ },
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\88c548461109b0c917067cfea58751b3\\appcompat-1.0.0-alpha1\\res\\values-gu\\values-gu.xml",
+ "from": {
+ "startLines": "2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19,20,21,22,23,24,25,26,27,28,29",
+ "startColumns": "4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4",
+ "startOffsets": "105,214,318,425,512,613,736,813,891,982,1075,1174,1268,1369,1462,1557,1654,1745,1836,1916,2022,2124,2221,2330,2429,2539,2699,2802",
+ "endColumns": "108,103,106,86,100,122,76,77,90,92,98,93,100,92,94,96,90,90,79,105,101,96,108,98,109,159,102,79",
+ "endOffsets": "209,313,420,507,608,731,808,886,977,1070,1169,1263,1364,1457,1552,1649,1740,1831,1911,2017,2119,2216,2325,2424,2534,2694,2797,2877"
+ }
+ }
+ ]
+ },
+ {
+ "outputFile": "E:\\Note\\src\\app\\build\\intermediates\\res\\merged\\debug\\values-pt_values-pt.arsc.flat",
+ "map": [
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\88c548461109b0c917067cfea58751b3\\appcompat-1.0.0-alpha1\\res\\values-pt\\values-pt.xml",
+ "from": {
+ "startLines": "2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19,20,21,22,23,24,25,26,27,28,29",
+ "startColumns": "4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4",
+ "startOffsets": "105,225,331,438,527,628,746,829,909,1000,1093,1189,1283,1384,1477,1572,1667,1758,1849,1936,2043,2155,2257,2365,2472,2582,2744,2844",
+ "endColumns": "119,105,106,88,100,117,82,79,90,92,95,93,100,92,94,94,90,90,86,106,111,101,107,106,109,161,99,84",
+ "endOffsets": "220,326,433,522,623,741,824,904,995,1088,1184,1278,1379,1472,1567,1662,1753,1844,1931,2038,2150,2252,2360,2467,2577,2739,2839,2924"
+ }
+ },
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\6d11613c3b6a00a9ea456b5609ec43f7\\core-1.0.0\\res\\values-pt\\values-pt.xml",
+ "from": {
+ "startLines": "2",
+ "startColumns": "4",
+ "startOffsets": "55",
+ "endColumns": "100",
+ "endOffsets": "151"
+ },
+ "to": {
+ "startLines": "30",
+ "startColumns": "4",
+ "startOffsets": "2929",
+ "endColumns": "100",
+ "endOffsets": "3025"
+ }
+ }
+ ]
+ },
+ {
+ "outputFile": "E:\\Note\\src\\app\\build\\intermediates\\res\\merged\\debug\\values-ca_values-ca.arsc.flat",
+ "map": [
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\88c548461109b0c917067cfea58751b3\\appcompat-1.0.0-alpha1\\res\\values-ca\\values-ca.xml",
+ "from": {
+ "startLines": "2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19,20,21,22,23,24,25,26,27,28,29",
+ "startColumns": "4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4",
+ "startOffsets": "105,223,329,436,519,627,753,837,918,1009,1102,1196,1291,1390,1483,1576,1670,1761,1852,1935,2046,2155,2253,2363,2467,2575,2735,2834",
+ "endColumns": "117,105,106,82,107,125,83,80,90,92,93,94,98,92,92,93,90,90,82,110,108,97,109,103,107,159,98,80",
+ "endOffsets": "218,324,431,514,622,748,832,913,1004,1097,1191,1286,1385,1478,1571,1665,1756,1847,1930,2041,2150,2248,2358,2462,2570,2730,2829,2910"
+ }
+ },
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\6d11613c3b6a00a9ea456b5609ec43f7\\core-1.0.0\\res\\values-ca\\values-ca.xml",
+ "from": {
+ "startLines": "2",
+ "startColumns": "4",
+ "startOffsets": "55",
+ "endColumns": "100",
+ "endOffsets": "151"
+ },
+ "to": {
+ "startLines": "30",
+ "startColumns": "4",
+ "startOffsets": "2915",
+ "endColumns": "100",
+ "endOffsets": "3011"
+ }
+ }
+ ]
+ },
+ {
+ "outputFile": "E:\\Note\\src\\app\\build\\intermediates\\res\\merged\\debug\\values-lt_values-lt.arsc.flat",
+ "map": [
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\88c548461109b0c917067cfea58751b3\\appcompat-1.0.0-alpha1\\res\\values-lt\\values-lt.xml",
+ "from": {
+ "startLines": "2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19,20,21,22,23,24,25,26,27,28,29",
+ "startColumns": "4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4",
+ "startOffsets": "105,221,322,435,522,631,752,834,915,1009,1105,1203,1299,1403,1499,1597,1700,1794,1888,1973,2082,2191,2291,2401,2505,2618,2794,2895",
+ "endColumns": "115,100,112,86,108,120,81,80,93,95,97,95,103,95,97,102,93,93,84,108,108,99,109,103,112,175,100,82",
+ "endOffsets": "216,317,430,517,626,747,829,910,1004,1100,1198,1294,1398,1494,1592,1695,1789,1883,1968,2077,2186,2286,2396,2500,2613,2789,2890,2973"
+ }
+ },
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\6d11613c3b6a00a9ea456b5609ec43f7\\core-1.0.0\\res\\values-lt\\values-lt.xml",
+ "from": {
+ "startLines": "2",
+ "startColumns": "4",
+ "startOffsets": "55",
+ "endColumns": "100",
+ "endOffsets": "151"
+ },
+ "to": {
+ "startLines": "30",
+ "startColumns": "4",
+ "startOffsets": "2978",
+ "endColumns": "100",
+ "endOffsets": "3074"
+ }
+ }
+ ]
+ },
+ {
+ "outputFile": "E:\\Note\\src\\app\\build\\intermediates\\res\\merged\\debug\\values-sw_values-sw.arsc.flat",
+ "map": [
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\88c548461109b0c917067cfea58751b3\\appcompat-1.0.0-alpha1\\res\\values-sw\\values-sw.xml",
+ "from": {
+ "startLines": "2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19,20,21,22,23,24,25,26,27,28,29",
+ "startColumns": "4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4",
+ "startOffsets": "105,208,306,414,504,609,726,808,891,982,1075,1169,1263,1364,1457,1552,1647,1738,1830,1912,2013,2122,2221,2328,2437,2542,2704,2801",
+ "endColumns": "102,97,107,89,104,116,81,82,90,92,93,93,100,92,94,94,90,91,81,100,108,98,106,108,104,161,96,81",
+ "endOffsets": "203,301,409,499,604,721,803,886,977,1070,1164,1258,1359,1452,1547,1642,1733,1825,1907,2008,2117,2216,2323,2432,2537,2699,2796,2878"
+ }
+ },
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\6d11613c3b6a00a9ea456b5609ec43f7\\core-1.0.0\\res\\values-sw\\values-sw.xml",
+ "from": {
+ "startLines": "2",
+ "startColumns": "4",
+ "startOffsets": "55",
+ "endColumns": "100",
+ "endOffsets": "151"
+ },
+ "to": {
+ "startLines": "30",
+ "startColumns": "4",
+ "startOffsets": "2883",
+ "endColumns": "100",
+ "endOffsets": "2979"
+ }
+ }
+ ]
+ },
+ {
+ "outputFile": "E:\\Note\\src\\app\\build\\intermediates\\res\\merged\\debug\\values-af_values-af.arsc.flat",
+ "map": [
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\88c548461109b0c917067cfea58751b3\\appcompat-1.0.0-alpha1\\res\\values-af\\values-af.xml",
+ "from": {
+ "startLines": "2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19,20,21,22,23,24,25,26,27,28,29",
+ "startColumns": "4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4",
+ "startOffsets": "105,209,309,415,500,603,721,797,874,965,1058,1154,1248,1348,1441,1536,1635,1730,1824,1905,2012,2115,2212,2320,2422,2524,2678,2776",
+ "endColumns": "103,99,105,84,102,117,75,76,90,92,95,93,99,92,94,98,94,93,80,106,102,96,107,101,101,153,97,79",
+ "endOffsets": "204,304,410,495,598,716,792,869,960,1053,1149,1243,1343,1436,1531,1630,1725,1819,1900,2007,2110,2207,2315,2417,2519,2673,2771,2851"
+ }
+ },
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\6d11613c3b6a00a9ea456b5609ec43f7\\core-1.0.0\\res\\values-af\\values-af.xml",
+ "from": {
+ "startLines": "2",
+ "startColumns": "4",
+ "startOffsets": "55",
+ "endColumns": "100",
+ "endOffsets": "151"
+ },
+ "to": {
+ "startLines": "30",
+ "startColumns": "4",
+ "startOffsets": "2856",
+ "endColumns": "100",
+ "endOffsets": "2952"
+ }
+ }
+ ]
+ },
+ {
+ "outputFile": "E:\\Note\\src\\app\\build\\intermediates\\res\\merged\\debug\\values-v22_values-v22.arsc.flat",
+ "map": [
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\88c548461109b0c917067cfea58751b3\\appcompat-1.0.0-alpha1\\res\\values-v22\\values-v22.xml",
+ "from": {
+ "startLines": "2,3,4,9",
+ "startColumns": "4,4,4,4",
+ "startOffsets": "55,130,217,553",
+ "endLines": "2,3,8,13",
+ "endColumns": "74,86,12,12",
+ "endOffsets": "125,212,548,896"
+ }
+ }
+ ]
+ },
+ {
+ "outputFile": "E:\\Note\\src\\app\\build\\intermediates\\res\\merged\\debug\\values-eu_values-eu.arsc.flat",
+ "map": [
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\6d11613c3b6a00a9ea456b5609ec43f7\\core-1.0.0\\res\\values-eu\\values-eu.xml",
+ "from": {
+ "startLines": "2",
+ "startColumns": "4",
+ "startOffsets": "55",
+ "endColumns": "100",
+ "endOffsets": "151"
+ },
+ "to": {
+ "startLines": "30",
+ "startColumns": "4",
+ "startOffsets": "2938",
+ "endColumns": "100",
+ "endOffsets": "3034"
+ }
+ },
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\88c548461109b0c917067cfea58751b3\\appcompat-1.0.0-alpha1\\res\\values-eu\\values-eu.xml",
+ "from": {
+ "startLines": "2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19,20,21,22,23,24,25,26,27,28,29",
+ "startColumns": "4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4",
+ "startOffsets": "105,214,312,422,508,614,738,825,909,1001,1095,1192,1286,1388,1482,1578,1675,1767,1860,1942,2051,2161,2260,2369,2475,2586,2757,2856",
+ "endColumns": "108,97,109,85,105,123,86,83,91,93,96,93,101,93,95,96,91,92,81,108,109,98,108,105,110,170,98,81",
+ "endOffsets": "209,307,417,503,609,733,820,904,996,1090,1187,1281,1383,1477,1573,1670,1762,1855,1937,2046,2156,2255,2364,2470,2581,2752,2851,2933"
+ }
+ }
+ ]
+ },
+ {
+ "outputFile": "E:\\Note\\src\\app\\build\\intermediates\\res\\merged\\debug\\values-fi_values-fi.arsc.flat",
+ "map": [
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\88c548461109b0c917067cfea58751b3\\appcompat-1.0.0-alpha1\\res\\values-fi\\values-fi.xml",
+ "from": {
+ "startLines": "2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19,20,21,22,23,24,25,26,27,28,29",
+ "startColumns": "4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4",
+ "startOffsets": "105,213,313,414,500,605,723,810,892,983,1076,1172,1266,1361,1454,1550,1649,1740,1834,1914,2021,2124,2221,2327,2426,2530,2693,2792",
+ "endColumns": "107,99,100,85,104,117,86,81,90,92,95,93,94,92,95,98,90,93,79,106,102,96,105,98,103,162,98,79",
+ "endOffsets": "208,308,409,495,600,718,805,887,978,1071,1167,1261,1356,1449,1545,1644,1735,1829,1909,2016,2119,2216,2322,2421,2525,2688,2787,2867"
+ }
+ },
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\6d11613c3b6a00a9ea456b5609ec43f7\\core-1.0.0\\res\\values-fi\\values-fi.xml",
+ "from": {
+ "startLines": "2",
+ "startColumns": "4",
+ "startOffsets": "55",
+ "endColumns": "100",
+ "endOffsets": "151"
+ },
+ "to": {
+ "startLines": "30",
+ "startColumns": "4",
+ "startOffsets": "2872",
+ "endColumns": "100",
+ "endOffsets": "2968"
+ }
+ }
+ ]
+ },
+ {
+ "outputFile": "E:\\Note\\src\\app\\build\\intermediates\\res\\merged\\debug\\values-v24_values-v24.arsc.flat",
+ "map": [
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\702974eead929cb167f132efe0eabb04\\media-1.0.0\\res\\values-v24\\values-v24.xml",
+ "from": {
+ "startLines": "2,3,4,5",
+ "startColumns": "4,4,4,4",
+ "startOffsets": "55,121,182,248",
+ "endColumns": "65,60,65,66",
+ "endOffsets": "116,177,243,310"
+ },
+ "to": {
+ "startLines": "4,5,6,7",
+ "startColumns": "4,4,4,4",
+ "startOffsets": "347,413,474,540",
+ "endColumns": "65,60,65,66",
+ "endOffsets": "408,469,535,602"
+ }
+ },
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\88c548461109b0c917067cfea58751b3\\appcompat-1.0.0-alpha1\\res\\values-v24\\values-v24.xml",
+ "from": {
+ "startLines": "2,3",
+ "startColumns": "4,4",
+ "startOffsets": "55,212",
+ "endColumns": "156,134",
+ "endOffsets": "207,342"
+ }
+ }
+ ]
+ },
+ {
+ "outputFile": "E:\\Note\\src\\app\\build\\intermediates\\res\\merged\\debug\\values-si_values-si.arsc.flat",
+ "map": [
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\6d11613c3b6a00a9ea456b5609ec43f7\\core-1.0.0\\res\\values-si\\values-si.xml",
+ "from": {
+ "startLines": "2",
+ "startColumns": "4",
+ "startOffsets": "55",
+ "endColumns": "100",
+ "endOffsets": "151"
+ },
+ "to": {
+ "startLines": "30",
+ "startColumns": "4",
+ "startOffsets": "2903",
+ "endColumns": "100",
+ "endOffsets": "2999"
+ }
+ },
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\88c548461109b0c917067cfea58751b3\\appcompat-1.0.0-alpha1\\res\\values-si\\values-si.xml",
+ "from": {
+ "startLines": "2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19,20,21,22,23,24,25,26,27,28,29",
+ "startColumns": "4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4",
+ "startOffsets": "105,215,322,429,517,622,738,827,914,1005,1098,1193,1287,1388,1481,1576,1670,1761,1852,1936,2045,2150,2248,2358,2457,2563,2722,2821",
+ "endColumns": "109,106,106,87,104,115,88,86,90,92,94,93,100,92,94,93,90,90,83,108,104,97,109,98,105,158,98,81",
+ "endOffsets": "210,317,424,512,617,733,822,909,1000,1093,1188,1282,1383,1476,1571,1665,1756,1847,1931,2040,2145,2243,2353,2452,2558,2717,2816,2898"
+ }
+ }
+ ]
+ },
+ {
+ "outputFile": "E:\\Note\\src\\app\\build\\intermediates\\res\\merged\\debug\\values-en-rAU_values-en-rAU.arsc.flat",
+ "map": [
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\6d11613c3b6a00a9ea456b5609ec43f7\\core-1.0.0\\res\\values-en-rAU\\values-en-rAU.xml",
+ "from": {
+ "startLines": "2",
+ "startColumns": "4",
+ "startOffsets": "55",
+ "endColumns": "100",
+ "endOffsets": "151"
+ },
+ "to": {
+ "startLines": "30",
+ "startColumns": "4",
+ "startOffsets": "2846",
+ "endColumns": "100",
+ "endOffsets": "2942"
+ }
+ },
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\88c548461109b0c917067cfea58751b3\\appcompat-1.0.0-alpha1\\res\\values-en-rAU\\values-en-rAU.xml",
+ "from": {
+ "startLines": "2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19,20,21,22,23,24,25,26,27,28,29",
+ "startColumns": "4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4",
+ "startOffsets": "105,209,309,417,501,601,716,793,869,960,1053,1149,1243,1344,1437,1532,1626,1717,1808,1890,1993,2097,2196,2301,2404,2508,2664,2764",
+ "endColumns": "103,99,107,83,99,114,76,75,90,92,95,93,100,92,94,93,90,90,81,102,103,98,104,102,103,155,99,81",
+ "endOffsets": "204,304,412,496,596,711,788,864,955,1048,1144,1238,1339,1432,1527,1621,1712,1803,1885,1988,2092,2191,2296,2399,2503,2659,2759,2841"
+ }
+ }
+ ]
+ }
+ ]
+}
\ No newline at end of file
diff --git a/src/src/app/build/intermediates/blame/res/debug/multi-v2/values-af.json b/src/src/app/build/intermediates/blame/res/debug/multi-v2/values-af.json
new file mode 100644
index 0000000..8983e27
--- /dev/null
+++ b/src/src/app/build/intermediates/blame/res/debug/multi-v2/values-af.json
@@ -0,0 +1,36 @@
+{
+ "logs": [
+ {
+ "outputFile": "E:\\Note\\src\\app\\build\\intermediates\\incremental\\mergeDebugResources\\merged.dir\\values-af\\values-af.xml",
+ "map": [
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\88c548461109b0c917067cfea58751b3\\appcompat-1.0.0-alpha1\\res\\values-af\\values-af.xml",
+ "from": {
+ "startLines": "2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19,20,21,22,23,24,25,26,27,28,29",
+ "startColumns": "4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4",
+ "startOffsets": "105,209,309,415,500,603,721,797,874,965,1058,1154,1248,1348,1441,1536,1635,1730,1824,1905,2012,2115,2212,2320,2422,2524,2678,2776",
+ "endColumns": "103,99,105,84,102,117,75,76,90,92,95,93,99,92,94,98,94,93,80,106,102,96,107,101,101,153,97,79",
+ "endOffsets": "204,304,410,495,598,716,792,869,960,1053,1149,1243,1343,1436,1531,1630,1725,1819,1900,2007,2110,2207,2315,2417,2519,2673,2771,2851"
+ }
+ },
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\6d11613c3b6a00a9ea456b5609ec43f7\\core-1.0.0\\res\\values-af\\values-af.xml",
+ "from": {
+ "startLines": "2",
+ "startColumns": "4",
+ "startOffsets": "55",
+ "endColumns": "100",
+ "endOffsets": "151"
+ },
+ "to": {
+ "startLines": "30",
+ "startColumns": "4",
+ "startOffsets": "2856",
+ "endColumns": "100",
+ "endOffsets": "2952"
+ }
+ }
+ ]
+ }
+ ]
+}
\ No newline at end of file
diff --git a/src/src/app/build/intermediates/blame/res/debug/multi-v2/values-am.json b/src/src/app/build/intermediates/blame/res/debug/multi-v2/values-am.json
new file mode 100644
index 0000000..1119a74
--- /dev/null
+++ b/src/src/app/build/intermediates/blame/res/debug/multi-v2/values-am.json
@@ -0,0 +1,36 @@
+{
+ "logs": [
+ {
+ "outputFile": "E:\\Note\\src\\app\\build\\intermediates\\incremental\\mergeDebugResources\\merged.dir\\values-am\\values-am.xml",
+ "map": [
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\6d11613c3b6a00a9ea456b5609ec43f7\\core-1.0.0\\res\\values-am\\values-am.xml",
+ "from": {
+ "startLines": "2",
+ "startColumns": "4",
+ "startOffsets": "55",
+ "endColumns": "100",
+ "endOffsets": "151"
+ },
+ "to": {
+ "startLines": "30",
+ "startColumns": "4",
+ "startOffsets": "2817",
+ "endColumns": "100",
+ "endOffsets": "2913"
+ }
+ },
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\88c548461109b0c917067cfea58751b3\\appcompat-1.0.0-alpha1\\res\\values-am\\values-am.xml",
+ "from": {
+ "startLines": "2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19,20,21,22,23,24,25,26,27,28,29",
+ "startColumns": "4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4",
+ "startOffsets": "105,207,306,412,498,601,714,792,870,961,1054,1147,1241,1342,1435,1530,1624,1715,1805,1884,1984,2084,2180,2283,2382,2489,2642,2738",
+ "endColumns": "101,98,105,85,102,112,77,77,90,92,92,93,100,92,94,93,90,89,78,99,99,95,102,98,106,152,95,78",
+ "endOffsets": "202,301,407,493,596,709,787,865,956,1049,1142,1236,1337,1430,1525,1619,1710,1800,1879,1979,2079,2175,2278,2377,2484,2637,2733,2812"
+ }
+ }
+ ]
+ }
+ ]
+}
\ No newline at end of file
diff --git a/src/src/app/build/intermediates/blame/res/debug/multi-v2/values-ar.json b/src/src/app/build/intermediates/blame/res/debug/multi-v2/values-ar.json
new file mode 100644
index 0000000..b29498a
--- /dev/null
+++ b/src/src/app/build/intermediates/blame/res/debug/multi-v2/values-ar.json
@@ -0,0 +1,36 @@
+{
+ "logs": [
+ {
+ "outputFile": "E:\\Note\\src\\app\\build\\intermediates\\incremental\\mergeDebugResources\\merged.dir\\values-ar\\values-ar.xml",
+ "map": [
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\6d11613c3b6a00a9ea456b5609ec43f7\\core-1.0.0\\res\\values-ar\\values-ar.xml",
+ "from": {
+ "startLines": "2",
+ "startColumns": "4",
+ "startOffsets": "55",
+ "endColumns": "100",
+ "endOffsets": "151"
+ },
+ "to": {
+ "startLines": "30",
+ "startColumns": "4",
+ "startOffsets": "2860",
+ "endColumns": "100",
+ "endOffsets": "2956"
+ }
+ },
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\88c548461109b0c917067cfea58751b3\\appcompat-1.0.0-alpha1\\res\\values-ar\\values-ar.xml",
+ "from": {
+ "startLines": "2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19,20,21,22,23,24,25,26,27,28,29",
+ "startColumns": "4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4",
+ "startOffsets": "105,222,326,435,517,618,732,811,890,981,1074,1170,1264,1365,1458,1553,1647,1738,1832,1911,2016,2117,2213,2321,2424,2527,2682,2779",
+ "endColumns": "116,103,108,81,100,113,78,78,90,92,95,93,100,92,94,93,90,93,78,104,100,95,107,102,102,154,96,80",
+ "endOffsets": "217,321,430,512,613,727,806,885,976,1069,1165,1259,1360,1453,1548,1642,1733,1827,1906,2011,2112,2208,2316,2419,2522,2677,2774,2855"
+ }
+ }
+ ]
+ }
+ ]
+}
\ No newline at end of file
diff --git a/src/src/app/build/intermediates/blame/res/debug/multi-v2/values-as.json b/src/src/app/build/intermediates/blame/res/debug/multi-v2/values-as.json
new file mode 100644
index 0000000..720ece8
--- /dev/null
+++ b/src/src/app/build/intermediates/blame/res/debug/multi-v2/values-as.json
@@ -0,0 +1,36 @@
+{
+ "logs": [
+ {
+ "outputFile": "E:\\Note\\src\\app\\build\\intermediates\\incremental\\mergeDebugResources\\merged.dir\\values-as\\values-as.xml",
+ "map": [
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\6d11613c3b6a00a9ea456b5609ec43f7\\core-1.0.0\\res\\values-as\\values-as.xml",
+ "from": {
+ "startLines": "2",
+ "startColumns": "4",
+ "startOffsets": "55",
+ "endColumns": "100",
+ "endOffsets": "151"
+ },
+ "to": {
+ "startLines": "30",
+ "startColumns": "4",
+ "startOffsets": "2950",
+ "endColumns": "100",
+ "endOffsets": "3046"
+ }
+ },
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\88c548461109b0c917067cfea58751b3\\appcompat-1.0.0-alpha1\\res\\values-as\\values-as.xml",
+ "from": {
+ "startLines": "2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19,20,21,22,23,24,25,26,27,28,29",
+ "startColumns": "4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4",
+ "startOffsets": "105,213,312,419,515,617,736,816,896,987,1080,1173,1268,1368,1461,1558,1652,1743,1834,1923,2025,2140,2243,2352,2471,2591,2758,2861",
+ "endColumns": "107,98,106,95,101,118,79,79,90,92,92,94,99,92,96,93,90,90,88,101,114,102,108,118,119,166,102,88",
+ "endOffsets": "208,307,414,510,612,731,811,891,982,1075,1168,1263,1363,1456,1553,1647,1738,1829,1918,2020,2135,2238,2347,2466,2586,2753,2856,2945"
+ }
+ }
+ ]
+ }
+ ]
+}
\ No newline at end of file
diff --git a/src/src/app/build/intermediates/blame/res/debug/multi-v2/values-az.json b/src/src/app/build/intermediates/blame/res/debug/multi-v2/values-az.json
new file mode 100644
index 0000000..c4a17f8
--- /dev/null
+++ b/src/src/app/build/intermediates/blame/res/debug/multi-v2/values-az.json
@@ -0,0 +1,36 @@
+{
+ "logs": [
+ {
+ "outputFile": "E:\\Note\\src\\app\\build\\intermediates\\incremental\\mergeDebugResources\\merged.dir\\values-az\\values-az.xml",
+ "map": [
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\6d11613c3b6a00a9ea456b5609ec43f7\\core-1.0.0\\res\\values-az\\values-az.xml",
+ "from": {
+ "startLines": "2",
+ "startColumns": "4",
+ "startOffsets": "55",
+ "endColumns": "100",
+ "endOffsets": "151"
+ },
+ "to": {
+ "startLines": "30",
+ "startColumns": "4",
+ "startOffsets": "2903",
+ "endColumns": "100",
+ "endOffsets": "2999"
+ }
+ },
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\88c548461109b0c917067cfea58751b3\\appcompat-1.0.0-alpha1\\res\\values-az\\values-az.xml",
+ "from": {
+ "startLines": "2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19,20,21,22,23,24,25,26,27,28,29",
+ "startColumns": "4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4",
+ "startOffsets": "105,213,312,424,512,619,733,814,893,984,1077,1172,1271,1372,1465,1560,1655,1746,1838,1923,2030,2137,2237,2346,2450,2560,2718,2820",
+ "endColumns": "107,98,111,87,106,113,80,78,90,92,94,98,100,92,94,94,90,91,84,106,106,99,108,103,109,157,101,82",
+ "endOffsets": "208,307,419,507,614,728,809,888,979,1072,1167,1266,1367,1460,1555,1650,1741,1833,1918,2025,2132,2232,2341,2445,2555,2713,2815,2898"
+ }
+ }
+ ]
+ }
+ ]
+}
\ No newline at end of file
diff --git a/src/src/app/build/intermediates/blame/res/debug/multi-v2/values-b+sr+Latn.json b/src/src/app/build/intermediates/blame/res/debug/multi-v2/values-b+sr+Latn.json
new file mode 100644
index 0000000..1b64714
--- /dev/null
+++ b/src/src/app/build/intermediates/blame/res/debug/multi-v2/values-b+sr+Latn.json
@@ -0,0 +1,36 @@
+{
+ "logs": [
+ {
+ "outputFile": "E:\\Note\\src\\app\\build\\intermediates\\incremental\\mergeDebugResources\\merged.dir\\values-b+sr+Latn\\values-b+sr+Latn.xml",
+ "map": [
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\6d11613c3b6a00a9ea456b5609ec43f7\\core-1.0.0\\res\\values-b+sr+Latn\\values-b+sr+Latn.xml",
+ "from": {
+ "startLines": "2",
+ "startColumns": "4",
+ "startOffsets": "55",
+ "endColumns": "100",
+ "endOffsets": "151"
+ },
+ "to": {
+ "startLines": "30",
+ "startColumns": "4",
+ "startOffsets": "2912",
+ "endColumns": "100",
+ "endOffsets": "3008"
+ }
+ },
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\88c548461109b0c917067cfea58751b3\\appcompat-1.0.0-alpha1\\res\\values-b+sr+Latn\\values-b+sr+Latn.xml",
+ "from": {
+ "startLines": "2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19,20,21,22,23,24,25,26,27,28,29",
+ "startColumns": "4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4",
+ "startOffsets": "105,214,318,424,510,614,732,814,895,986,1079,1175,1269,1370,1463,1558,1663,1754,1845,1933,2039,2147,2248,2353,2461,2562,2731,2828",
+ "endColumns": "108,103,105,85,103,117,81,80,90,92,95,93,100,92,94,104,90,90,87,105,107,100,104,107,100,168,96,83",
+ "endOffsets": "209,313,419,505,609,727,809,890,981,1074,1170,1264,1365,1458,1553,1658,1749,1840,1928,2034,2142,2243,2348,2456,2557,2726,2823,2907"
+ }
+ }
+ ]
+ }
+ ]
+}
\ No newline at end of file
diff --git a/src/src/app/build/intermediates/blame/res/debug/multi-v2/values-be.json b/src/src/app/build/intermediates/blame/res/debug/multi-v2/values-be.json
new file mode 100644
index 0000000..48b7902
--- /dev/null
+++ b/src/src/app/build/intermediates/blame/res/debug/multi-v2/values-be.json
@@ -0,0 +1,36 @@
+{
+ "logs": [
+ {
+ "outputFile": "E:\\Note\\src\\app\\build\\intermediates\\incremental\\mergeDebugResources\\merged.dir\\values-be\\values-be.xml",
+ "map": [
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\6d11613c3b6a00a9ea456b5609ec43f7\\core-1.0.0\\res\\values-be\\values-be.xml",
+ "from": {
+ "startLines": "2",
+ "startColumns": "4",
+ "startOffsets": "55",
+ "endColumns": "100",
+ "endOffsets": "151"
+ },
+ "to": {
+ "startLines": "30",
+ "startColumns": "4",
+ "startOffsets": "2915",
+ "endColumns": "100",
+ "endOffsets": "3011"
+ }
+ },
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\88c548461109b0c917067cfea58751b3\\appcompat-1.0.0-alpha1\\res\\values-be\\values-be.xml",
+ "from": {
+ "startLines": "2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19,20,21,22,23,24,25,26,27,28,29",
+ "startColumns": "4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4",
+ "startOffsets": "105,225,328,444,530,638,756,835,913,1005,1099,1195,1289,1385,1479,1575,1670,1762,1854,1937,2043,2149,2247,2355,2460,2565,2734,2834",
+ "endColumns": "119,102,115,85,107,117,78,77,91,93,95,93,95,93,95,94,91,91,82,105,105,97,107,104,104,168,99,80",
+ "endOffsets": "220,323,439,525,633,751,830,908,1000,1094,1190,1284,1380,1474,1570,1665,1757,1849,1932,2038,2144,2242,2350,2455,2560,2729,2829,2910"
+ }
+ }
+ ]
+ }
+ ]
+}
\ No newline at end of file
diff --git a/src/src/app/build/intermediates/blame/res/debug/multi-v2/values-bg.json b/src/src/app/build/intermediates/blame/res/debug/multi-v2/values-bg.json
new file mode 100644
index 0000000..e4ec396
--- /dev/null
+++ b/src/src/app/build/intermediates/blame/res/debug/multi-v2/values-bg.json
@@ -0,0 +1,36 @@
+{
+ "logs": [
+ {
+ "outputFile": "E:\\Note\\src\\app\\build\\intermediates\\incremental\\mergeDebugResources\\merged.dir\\values-bg\\values-bg.xml",
+ "map": [
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\6d11613c3b6a00a9ea456b5609ec43f7\\core-1.0.0\\res\\values-bg\\values-bg.xml",
+ "from": {
+ "startLines": "2",
+ "startColumns": "4",
+ "startOffsets": "55",
+ "endColumns": "100",
+ "endOffsets": "151"
+ },
+ "to": {
+ "startLines": "30",
+ "startColumns": "4",
+ "startOffsets": "2930",
+ "endColumns": "100",
+ "endOffsets": "3026"
+ }
+ },
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\88c548461109b0c917067cfea58751b3\\appcompat-1.0.0-alpha1\\res\\values-bg\\values-bg.xml",
+ "from": {
+ "startLines": "2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19,20,21,22,23,24,25,26,27,28,29",
+ "startColumns": "4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4",
+ "startOffsets": "105,220,327,432,518,623,744,823,901,992,1085,1181,1275,1376,1469,1564,1672,1763,1854,1937,2051,2160,2260,2374,2480,2588,2748,2847",
+ "endColumns": "114,106,104,85,104,120,78,77,90,92,95,93,100,92,94,107,90,90,82,113,108,99,113,105,107,159,98,82",
+ "endOffsets": "215,322,427,513,618,739,818,896,987,1080,1176,1270,1371,1464,1559,1667,1758,1849,1932,2046,2155,2255,2369,2475,2583,2743,2842,2925"
+ }
+ }
+ ]
+ }
+ ]
+}
\ No newline at end of file
diff --git a/src/src/app/build/intermediates/blame/res/debug/multi-v2/values-bn.json b/src/src/app/build/intermediates/blame/res/debug/multi-v2/values-bn.json
new file mode 100644
index 0000000..02b8bf1
--- /dev/null
+++ b/src/src/app/build/intermediates/blame/res/debug/multi-v2/values-bn.json
@@ -0,0 +1,36 @@
+{
+ "logs": [
+ {
+ "outputFile": "E:\\Note\\src\\app\\build\\intermediates\\incremental\\mergeDebugResources\\merged.dir\\values-bn\\values-bn.xml",
+ "map": [
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\88c548461109b0c917067cfea58751b3\\appcompat-1.0.0-alpha1\\res\\values-bn\\values-bn.xml",
+ "from": {
+ "startLines": "2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19,20,21,22,23,24,25,26,27,28,29",
+ "startColumns": "4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4",
+ "startOffsets": "105,214,326,432,526,631,760,838,916,1007,1100,1195,1289,1390,1483,1578,1672,1763,1854,1941,2051,2159,2258,2368,2474,2587,2752,2857",
+ "endColumns": "108,111,105,93,104,128,77,77,90,92,94,93,100,92,94,93,90,90,86,109,107,98,109,105,112,164,104,81",
+ "endOffsets": "209,321,427,521,626,755,833,911,1002,1095,1190,1284,1385,1478,1573,1667,1758,1849,1936,2046,2154,2253,2363,2469,2582,2747,2852,2934"
+ }
+ },
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\6d11613c3b6a00a9ea456b5609ec43f7\\core-1.0.0\\res\\values-bn\\values-bn.xml",
+ "from": {
+ "startLines": "2",
+ "startColumns": "4",
+ "startOffsets": "55",
+ "endColumns": "100",
+ "endOffsets": "151"
+ },
+ "to": {
+ "startLines": "30",
+ "startColumns": "4",
+ "startOffsets": "2939",
+ "endColumns": "100",
+ "endOffsets": "3035"
+ }
+ }
+ ]
+ }
+ ]
+}
\ No newline at end of file
diff --git a/src/src/app/build/intermediates/blame/res/debug/multi-v2/values-bs.json b/src/src/app/build/intermediates/blame/res/debug/multi-v2/values-bs.json
new file mode 100644
index 0000000..ac70f9d
--- /dev/null
+++ b/src/src/app/build/intermediates/blame/res/debug/multi-v2/values-bs.json
@@ -0,0 +1,36 @@
+{
+ "logs": [
+ {
+ "outputFile": "E:\\Note\\src\\app\\build\\intermediates\\incremental\\mergeDebugResources\\merged.dir\\values-bs\\values-bs.xml",
+ "map": [
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\88c548461109b0c917067cfea58751b3\\appcompat-1.0.0-alpha1\\res\\values-bs\\values-bs.xml",
+ "from": {
+ "startLines": "2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19,20,21,22,23,24,25,26,27,28,29",
+ "startColumns": "4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4",
+ "startOffsets": "105,224,333,440,526,630,752,834,915,1006,1099,1195,1289,1390,1483,1578,1677,1768,1859,1945,2048,2153,2251,2356,2469,2572,2745,2842",
+ "endColumns": "118,108,106,85,103,121,81,80,90,92,95,93,100,92,94,98,90,90,85,102,104,97,104,112,102,172,96,83",
+ "endOffsets": "219,328,435,521,625,747,829,910,1001,1094,1190,1284,1385,1478,1573,1672,1763,1854,1940,2043,2148,2246,2351,2464,2567,2740,2837,2921"
+ }
+ },
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\6d11613c3b6a00a9ea456b5609ec43f7\\core-1.0.0\\res\\values-bs\\values-bs.xml",
+ "from": {
+ "startLines": "2",
+ "startColumns": "4",
+ "startOffsets": "55",
+ "endColumns": "100",
+ "endOffsets": "151"
+ },
+ "to": {
+ "startLines": "30",
+ "startColumns": "4",
+ "startOffsets": "2926",
+ "endColumns": "100",
+ "endOffsets": "3022"
+ }
+ }
+ ]
+ }
+ ]
+}
\ No newline at end of file
diff --git a/src/src/app/build/intermediates/blame/res/debug/multi-v2/values-ca.json b/src/src/app/build/intermediates/blame/res/debug/multi-v2/values-ca.json
new file mode 100644
index 0000000..c99cf6e
--- /dev/null
+++ b/src/src/app/build/intermediates/blame/res/debug/multi-v2/values-ca.json
@@ -0,0 +1,36 @@
+{
+ "logs": [
+ {
+ "outputFile": "E:\\Note\\src\\app\\build\\intermediates\\incremental\\mergeDebugResources\\merged.dir\\values-ca\\values-ca.xml",
+ "map": [
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\88c548461109b0c917067cfea58751b3\\appcompat-1.0.0-alpha1\\res\\values-ca\\values-ca.xml",
+ "from": {
+ "startLines": "2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19,20,21,22,23,24,25,26,27,28,29",
+ "startColumns": "4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4",
+ "startOffsets": "105,223,329,436,519,627,753,837,918,1009,1102,1196,1291,1390,1483,1576,1670,1761,1852,1935,2046,2155,2253,2363,2467,2575,2735,2834",
+ "endColumns": "117,105,106,82,107,125,83,80,90,92,93,94,98,92,92,93,90,90,82,110,108,97,109,103,107,159,98,80",
+ "endOffsets": "218,324,431,514,622,748,832,913,1004,1097,1191,1286,1385,1478,1571,1665,1756,1847,1930,2041,2150,2248,2358,2462,2570,2730,2829,2910"
+ }
+ },
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\6d11613c3b6a00a9ea456b5609ec43f7\\core-1.0.0\\res\\values-ca\\values-ca.xml",
+ "from": {
+ "startLines": "2",
+ "startColumns": "4",
+ "startOffsets": "55",
+ "endColumns": "100",
+ "endOffsets": "151"
+ },
+ "to": {
+ "startLines": "30",
+ "startColumns": "4",
+ "startOffsets": "2915",
+ "endColumns": "100",
+ "endOffsets": "3011"
+ }
+ }
+ ]
+ }
+ ]
+}
\ No newline at end of file
diff --git a/src/src/app/build/intermediates/blame/res/debug/multi-v2/values-cs.json b/src/src/app/build/intermediates/blame/res/debug/multi-v2/values-cs.json
new file mode 100644
index 0000000..77c3a92
--- /dev/null
+++ b/src/src/app/build/intermediates/blame/res/debug/multi-v2/values-cs.json
@@ -0,0 +1,36 @@
+{
+ "logs": [
+ {
+ "outputFile": "E:\\Note\\src\\app\\build\\intermediates\\incremental\\mergeDebugResources\\merged.dir\\values-cs\\values-cs.xml",
+ "map": [
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\88c548461109b0c917067cfea58751b3\\appcompat-1.0.0-alpha1\\res\\values-cs\\values-cs.xml",
+ "from": {
+ "startLines": "2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19,20,21,22,23,24,25,26,27,28,29",
+ "startColumns": "4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4",
+ "startOffsets": "105,212,314,423,509,614,731,812,893,984,1077,1173,1267,1362,1455,1550,1647,1738,1829,1913,2017,2126,2225,2331,2441,2548,2711,2809",
+ "endColumns": "106,101,108,85,104,116,80,80,90,92,95,93,94,92,94,96,90,90,83,103,108,98,105,109,106,162,97,81",
+ "endOffsets": "207,309,418,504,609,726,807,888,979,1072,1168,1262,1357,1450,1545,1642,1733,1824,1908,2012,2121,2220,2326,2436,2543,2706,2804,2886"
+ }
+ },
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\6d11613c3b6a00a9ea456b5609ec43f7\\core-1.0.0\\res\\values-cs\\values-cs.xml",
+ "from": {
+ "startLines": "2",
+ "startColumns": "4",
+ "startOffsets": "55",
+ "endColumns": "100",
+ "endOffsets": "151"
+ },
+ "to": {
+ "startLines": "30",
+ "startColumns": "4",
+ "startOffsets": "2891",
+ "endColumns": "100",
+ "endOffsets": "2987"
+ }
+ }
+ ]
+ }
+ ]
+}
\ No newline at end of file
diff --git a/src/src/app/build/intermediates/blame/res/debug/multi-v2/values-da.json b/src/src/app/build/intermediates/blame/res/debug/multi-v2/values-da.json
new file mode 100644
index 0000000..0abead5
--- /dev/null
+++ b/src/src/app/build/intermediates/blame/res/debug/multi-v2/values-da.json
@@ -0,0 +1,36 @@
+{
+ "logs": [
+ {
+ "outputFile": "E:\\Note\\src\\app\\build\\intermediates\\incremental\\mergeDebugResources\\merged.dir\\values-da\\values-da.xml",
+ "map": [
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\6d11613c3b6a00a9ea456b5609ec43f7\\core-1.0.0\\res\\values-da\\values-da.xml",
+ "from": {
+ "startLines": "2",
+ "startColumns": "4",
+ "startOffsets": "55",
+ "endColumns": "100",
+ "endOffsets": "151"
+ },
+ "to": {
+ "startLines": "30",
+ "startColumns": "4",
+ "startOffsets": "2844",
+ "endColumns": "100",
+ "endOffsets": "2940"
+ }
+ },
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\88c548461109b0c917067cfea58751b3\\appcompat-1.0.0-alpha1\\res\\values-da\\values-da.xml",
+ "from": {
+ "startLines": "2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19,20,21,22,23,24,25,26,27,28,29",
+ "startColumns": "4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4",
+ "startOffsets": "105,208,307,419,502,602,715,792,869,960,1053,1149,1243,1338,1431,1526,1624,1715,1806,1885,1994,2102,2198,2312,2414,2515,2668,2765",
+ "endColumns": "102,98,111,82,99,112,76,76,90,92,95,93,94,92,94,97,90,90,78,108,107,95,113,101,100,152,96,78",
+ "endOffsets": "203,302,414,497,597,710,787,864,955,1048,1144,1238,1333,1426,1521,1619,1710,1801,1880,1989,2097,2193,2307,2409,2510,2663,2760,2839"
+ }
+ }
+ ]
+ }
+ ]
+}
\ No newline at end of file
diff --git a/src/src/app/build/intermediates/blame/res/debug/multi-v2/values-de.json b/src/src/app/build/intermediates/blame/res/debug/multi-v2/values-de.json
new file mode 100644
index 0000000..c31595e
--- /dev/null
+++ b/src/src/app/build/intermediates/blame/res/debug/multi-v2/values-de.json
@@ -0,0 +1,36 @@
+{
+ "logs": [
+ {
+ "outputFile": "E:\\Note\\src\\app\\build\\intermediates\\incremental\\mergeDebugResources\\merged.dir\\values-de\\values-de.xml",
+ "map": [
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\88c548461109b0c917067cfea58751b3\\appcompat-1.0.0-alpha1\\res\\values-de\\values-de.xml",
+ "from": {
+ "startLines": "2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19,20,21,22,23,24,25,26,27,28,29",
+ "startColumns": "4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4",
+ "startOffsets": "105,210,308,420,506,611,726,803,879,971,1065,1162,1263,1371,1471,1575,1675,1773,1870,1952,2063,2166,2265,2376,2478,2585,2741,2843",
+ "endColumns": "104,97,111,85,104,114,76,75,91,93,96,100,107,99,103,99,97,96,81,110,102,98,110,101,106,155,101,81",
+ "endOffsets": "205,303,415,501,606,721,798,874,966,1060,1157,1258,1366,1466,1570,1670,1768,1865,1947,2058,2161,2260,2371,2473,2580,2736,2838,2920"
+ }
+ },
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\6d11613c3b6a00a9ea456b5609ec43f7\\core-1.0.0\\res\\values-de\\values-de.xml",
+ "from": {
+ "startLines": "2",
+ "startColumns": "4",
+ "startOffsets": "55",
+ "endColumns": "100",
+ "endOffsets": "151"
+ },
+ "to": {
+ "startLines": "30",
+ "startColumns": "4",
+ "startOffsets": "2925",
+ "endColumns": "100",
+ "endOffsets": "3021"
+ }
+ }
+ ]
+ }
+ ]
+}
\ No newline at end of file
diff --git a/src/src/app/build/intermediates/blame/res/debug/multi-v2/values-el.json b/src/src/app/build/intermediates/blame/res/debug/multi-v2/values-el.json
new file mode 100644
index 0000000..75d9864
--- /dev/null
+++ b/src/src/app/build/intermediates/blame/res/debug/multi-v2/values-el.json
@@ -0,0 +1,36 @@
+{
+ "logs": [
+ {
+ "outputFile": "E:\\Note\\src\\app\\build\\intermediates\\incremental\\mergeDebugResources\\merged.dir\\values-el\\values-el.xml",
+ "map": [
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\88c548461109b0c917067cfea58751b3\\appcompat-1.0.0-alpha1\\res\\values-el\\values-el.xml",
+ "from": {
+ "startLines": "2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19,20,21,22,23,24,25,26,27,28,29",
+ "startColumns": "4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4",
+ "startOffsets": "105,223,334,451,536,641,767,855,941,1032,1125,1221,1315,1416,1509,1604,1701,1792,1883,1968,2079,2189,2291,2402,2511,2619,2779,2879",
+ "endColumns": "117,110,116,84,104,125,87,85,90,92,95,93,100,92,94,96,90,90,84,110,109,101,110,108,107,159,99,84",
+ "endOffsets": "218,329,446,531,636,762,850,936,1027,1120,1216,1310,1411,1504,1599,1696,1787,1878,1963,2074,2184,2286,2397,2506,2614,2774,2874,2959"
+ }
+ },
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\6d11613c3b6a00a9ea456b5609ec43f7\\core-1.0.0\\res\\values-el\\values-el.xml",
+ "from": {
+ "startLines": "2",
+ "startColumns": "4",
+ "startOffsets": "55",
+ "endColumns": "100",
+ "endOffsets": "151"
+ },
+ "to": {
+ "startLines": "30",
+ "startColumns": "4",
+ "startOffsets": "2964",
+ "endColumns": "100",
+ "endOffsets": "3060"
+ }
+ }
+ ]
+ }
+ ]
+}
\ No newline at end of file
diff --git a/src/src/app/build/intermediates/blame/res/debug/multi-v2/values-en-rAU.json b/src/src/app/build/intermediates/blame/res/debug/multi-v2/values-en-rAU.json
new file mode 100644
index 0000000..44ea9f2
--- /dev/null
+++ b/src/src/app/build/intermediates/blame/res/debug/multi-v2/values-en-rAU.json
@@ -0,0 +1,36 @@
+{
+ "logs": [
+ {
+ "outputFile": "E:\\Note\\src\\app\\build\\intermediates\\incremental\\mergeDebugResources\\merged.dir\\values-en-rAU\\values-en-rAU.xml",
+ "map": [
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\6d11613c3b6a00a9ea456b5609ec43f7\\core-1.0.0\\res\\values-en-rAU\\values-en-rAU.xml",
+ "from": {
+ "startLines": "2",
+ "startColumns": "4",
+ "startOffsets": "55",
+ "endColumns": "100",
+ "endOffsets": "151"
+ },
+ "to": {
+ "startLines": "30",
+ "startColumns": "4",
+ "startOffsets": "2846",
+ "endColumns": "100",
+ "endOffsets": "2942"
+ }
+ },
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\88c548461109b0c917067cfea58751b3\\appcompat-1.0.0-alpha1\\res\\values-en-rAU\\values-en-rAU.xml",
+ "from": {
+ "startLines": "2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19,20,21,22,23,24,25,26,27,28,29",
+ "startColumns": "4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4",
+ "startOffsets": "105,209,309,417,501,601,716,793,869,960,1053,1149,1243,1344,1437,1532,1626,1717,1808,1890,1993,2097,2196,2301,2404,2508,2664,2764",
+ "endColumns": "103,99,107,83,99,114,76,75,90,92,95,93,100,92,94,93,90,90,81,102,103,98,104,102,103,155,99,81",
+ "endOffsets": "204,304,412,496,596,711,788,864,955,1048,1144,1238,1339,1432,1527,1621,1712,1803,1885,1988,2092,2191,2296,2399,2503,2659,2759,2841"
+ }
+ }
+ ]
+ }
+ ]
+}
\ No newline at end of file
diff --git a/src/src/app/build/intermediates/blame/res/debug/multi-v2/values-en-rCA.json b/src/src/app/build/intermediates/blame/res/debug/multi-v2/values-en-rCA.json
new file mode 100644
index 0000000..723cde0
--- /dev/null
+++ b/src/src/app/build/intermediates/blame/res/debug/multi-v2/values-en-rCA.json
@@ -0,0 +1,36 @@
+{
+ "logs": [
+ {
+ "outputFile": "E:\\Note\\src\\app\\build\\intermediates\\incremental\\mergeDebugResources\\merged.dir\\values-en-rCA\\values-en-rCA.xml",
+ "map": [
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\88c548461109b0c917067cfea58751b3\\appcompat-1.0.0-alpha1\\res\\values-en-rCA\\values-en-rCA.xml",
+ "from": {
+ "startLines": "2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19,20,21,22,23,24,25,26,27,28,29",
+ "startColumns": "4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4",
+ "startOffsets": "105,209,309,417,501,601,716,793,869,960,1053,1149,1243,1344,1437,1532,1626,1717,1808,1890,1993,2097,2196,2301,2404,2508,2664,2764",
+ "endColumns": "103,99,107,83,99,114,76,75,90,92,95,93,100,92,94,93,90,90,81,102,103,98,104,102,103,155,99,81",
+ "endOffsets": "204,304,412,496,596,711,788,864,955,1048,1144,1238,1339,1432,1527,1621,1712,1803,1885,1988,2092,2191,2296,2399,2503,2659,2759,2841"
+ }
+ },
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\6d11613c3b6a00a9ea456b5609ec43f7\\core-1.0.0\\res\\values-en-rCA\\values-en-rCA.xml",
+ "from": {
+ "startLines": "2",
+ "startColumns": "4",
+ "startOffsets": "55",
+ "endColumns": "100",
+ "endOffsets": "151"
+ },
+ "to": {
+ "startLines": "30",
+ "startColumns": "4",
+ "startOffsets": "2846",
+ "endColumns": "100",
+ "endOffsets": "2942"
+ }
+ }
+ ]
+ }
+ ]
+}
\ No newline at end of file
diff --git a/src/src/app/build/intermediates/blame/res/debug/multi-v2/values-en-rGB.json b/src/src/app/build/intermediates/blame/res/debug/multi-v2/values-en-rGB.json
new file mode 100644
index 0000000..bf24f1a
--- /dev/null
+++ b/src/src/app/build/intermediates/blame/res/debug/multi-v2/values-en-rGB.json
@@ -0,0 +1,36 @@
+{
+ "logs": [
+ {
+ "outputFile": "E:\\Note\\src\\app\\build\\intermediates\\incremental\\mergeDebugResources\\merged.dir\\values-en-rGB\\values-en-rGB.xml",
+ "map": [
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\88c548461109b0c917067cfea58751b3\\appcompat-1.0.0-alpha1\\res\\values-en-rGB\\values-en-rGB.xml",
+ "from": {
+ "startLines": "2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19,20,21,22,23,24,25,26,27,28,29",
+ "startColumns": "4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4",
+ "startOffsets": "105,209,309,417,501,601,716,793,869,960,1053,1149,1243,1344,1437,1532,1626,1717,1808,1890,1993,2097,2196,2301,2404,2508,2664,2764",
+ "endColumns": "103,99,107,83,99,114,76,75,90,92,95,93,100,92,94,93,90,90,81,102,103,98,104,102,103,155,99,81",
+ "endOffsets": "204,304,412,496,596,711,788,864,955,1048,1144,1238,1339,1432,1527,1621,1712,1803,1885,1988,2092,2191,2296,2399,2503,2659,2759,2841"
+ }
+ },
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\6d11613c3b6a00a9ea456b5609ec43f7\\core-1.0.0\\res\\values-en-rGB\\values-en-rGB.xml",
+ "from": {
+ "startLines": "2",
+ "startColumns": "4",
+ "startOffsets": "55",
+ "endColumns": "100",
+ "endOffsets": "151"
+ },
+ "to": {
+ "startLines": "30",
+ "startColumns": "4",
+ "startOffsets": "2846",
+ "endColumns": "100",
+ "endOffsets": "2942"
+ }
+ }
+ ]
+ }
+ ]
+}
\ No newline at end of file
diff --git a/src/src/app/build/intermediates/blame/res/debug/multi-v2/values-en-rIN.json b/src/src/app/build/intermediates/blame/res/debug/multi-v2/values-en-rIN.json
new file mode 100644
index 0000000..2681c3e
--- /dev/null
+++ b/src/src/app/build/intermediates/blame/res/debug/multi-v2/values-en-rIN.json
@@ -0,0 +1,36 @@
+{
+ "logs": [
+ {
+ "outputFile": "E:\\Note\\src\\app\\build\\intermediates\\incremental\\mergeDebugResources\\merged.dir\\values-en-rIN\\values-en-rIN.xml",
+ "map": [
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\6d11613c3b6a00a9ea456b5609ec43f7\\core-1.0.0\\res\\values-en-rIN\\values-en-rIN.xml",
+ "from": {
+ "startLines": "2",
+ "startColumns": "4",
+ "startOffsets": "55",
+ "endColumns": "100",
+ "endOffsets": "151"
+ },
+ "to": {
+ "startLines": "30",
+ "startColumns": "4",
+ "startOffsets": "2846",
+ "endColumns": "100",
+ "endOffsets": "2942"
+ }
+ },
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\88c548461109b0c917067cfea58751b3\\appcompat-1.0.0-alpha1\\res\\values-en-rIN\\values-en-rIN.xml",
+ "from": {
+ "startLines": "2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19,20,21,22,23,24,25,26,27,28,29",
+ "startColumns": "4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4",
+ "startOffsets": "105,209,309,417,501,601,716,793,869,960,1053,1149,1243,1344,1437,1532,1626,1717,1808,1890,1993,2097,2196,2301,2404,2508,2664,2764",
+ "endColumns": "103,99,107,83,99,114,76,75,90,92,95,93,100,92,94,93,90,90,81,102,103,98,104,102,103,155,99,81",
+ "endOffsets": "204,304,412,496,596,711,788,864,955,1048,1144,1238,1339,1432,1527,1621,1712,1803,1885,1988,2092,2191,2296,2399,2503,2659,2759,2841"
+ }
+ }
+ ]
+ }
+ ]
+}
\ No newline at end of file
diff --git a/src/src/app/build/intermediates/blame/res/debug/multi-v2/values-en-rXC.json b/src/src/app/build/intermediates/blame/res/debug/multi-v2/values-en-rXC.json
new file mode 100644
index 0000000..6421ec6
--- /dev/null
+++ b/src/src/app/build/intermediates/blame/res/debug/multi-v2/values-en-rXC.json
@@ -0,0 +1,36 @@
+{
+ "logs": [
+ {
+ "outputFile": "E:\\Note\\src\\app\\build\\intermediates\\incremental\\mergeDebugResources\\merged.dir\\values-en-rXC\\values-en-rXC.xml",
+ "map": [
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\88c548461109b0c917067cfea58751b3\\appcompat-1.0.0-alpha1\\res\\values-en-rXC\\values-en-rXC.xml",
+ "from": {
+ "startLines": "2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19,20,21,22,23,24,25,26,27,28,29",
+ "startColumns": "4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4",
+ "startOffsets": "105,310,510,719,904,1106,1321,1494,1671,1862,2055,2253,2449,2652,2847,3044,3239,3432,3623,3807,4011,4216,4417,4624,4826,5031,5303,5503",
+ "endColumns": "204,199,208,184,201,214,172,176,190,192,197,195,202,194,196,194,192,190,183,203,204,200,206,201,204,271,199,178",
+ "endOffsets": "305,505,714,899,1101,1316,1489,1666,1857,2050,2248,2444,2647,2842,3039,3234,3427,3618,3802,4006,4211,4412,4619,4821,5026,5298,5498,5677"
+ }
+ },
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\6d11613c3b6a00a9ea456b5609ec43f7\\core-1.0.0\\res\\values-en-rXC\\values-en-rXC.xml",
+ "from": {
+ "startLines": "2",
+ "startColumns": "4",
+ "startOffsets": "55",
+ "endColumns": "202",
+ "endOffsets": "253"
+ },
+ "to": {
+ "startLines": "30",
+ "startColumns": "4",
+ "startOffsets": "5682",
+ "endColumns": "202",
+ "endOffsets": "5880"
+ }
+ }
+ ]
+ }
+ ]
+}
\ No newline at end of file
diff --git a/src/src/app/build/intermediates/blame/res/debug/multi-v2/values-es-rUS.json b/src/src/app/build/intermediates/blame/res/debug/multi-v2/values-es-rUS.json
new file mode 100644
index 0000000..a28b64b
--- /dev/null
+++ b/src/src/app/build/intermediates/blame/res/debug/multi-v2/values-es-rUS.json
@@ -0,0 +1,36 @@
+{
+ "logs": [
+ {
+ "outputFile": "E:\\Note\\src\\app\\build\\intermediates\\incremental\\mergeDebugResources\\merged.dir\\values-es-rUS\\values-es-rUS.xml",
+ "map": [
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\88c548461109b0c917067cfea58751b3\\appcompat-1.0.0-alpha1\\res\\values-es-rUS\\values-es-rUS.xml",
+ "from": {
+ "startLines": "2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19,20,21,22,23,24,25,26,27,28,29",
+ "startColumns": "4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4",
+ "startOffsets": "105,225,334,442,527,628,751,836,918,1009,1102,1198,1292,1392,1485,1584,1680,1771,1862,1944,2056,2156,2257,2365,2472,2579,2738,2838",
+ "endColumns": "119,108,107,84,100,122,84,81,90,92,95,93,99,92,98,95,90,90,81,111,99,100,107,106,106,158,99,81",
+ "endOffsets": "220,329,437,522,623,746,831,913,1004,1097,1193,1287,1387,1480,1579,1675,1766,1857,1939,2051,2151,2252,2360,2467,2574,2733,2833,2915"
+ }
+ },
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\6d11613c3b6a00a9ea456b5609ec43f7\\core-1.0.0\\res\\values-es-rUS\\values-es-rUS.xml",
+ "from": {
+ "startLines": "2",
+ "startColumns": "4",
+ "startOffsets": "55",
+ "endColumns": "100",
+ "endOffsets": "151"
+ },
+ "to": {
+ "startLines": "30",
+ "startColumns": "4",
+ "startOffsets": "2920",
+ "endColumns": "100",
+ "endOffsets": "3016"
+ }
+ }
+ ]
+ }
+ ]
+}
\ No newline at end of file
diff --git a/src/src/app/build/intermediates/blame/res/debug/multi-v2/values-es.json b/src/src/app/build/intermediates/blame/res/debug/multi-v2/values-es.json
new file mode 100644
index 0000000..54c10a7
--- /dev/null
+++ b/src/src/app/build/intermediates/blame/res/debug/multi-v2/values-es.json
@@ -0,0 +1,36 @@
+{
+ "logs": [
+ {
+ "outputFile": "E:\\Note\\src\\app\\build\\intermediates\\incremental\\mergeDebugResources\\merged.dir\\values-es\\values-es.xml",
+ "map": [
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\6d11613c3b6a00a9ea456b5609ec43f7\\core-1.0.0\\res\\values-es\\values-es.xml",
+ "from": {
+ "startLines": "2",
+ "startColumns": "4",
+ "startOffsets": "55",
+ "endColumns": "100",
+ "endOffsets": "151"
+ },
+ "to": {
+ "startLines": "30",
+ "startColumns": "4",
+ "startOffsets": "2924",
+ "endColumns": "100",
+ "endOffsets": "3020"
+ }
+ },
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\88c548461109b0c917067cfea58751b3\\appcompat-1.0.0-alpha1\\res\\values-es\\values-es.xml",
+ "from": {
+ "startLines": "2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19,20,21,22,23,24,25,26,27,28,29",
+ "startColumns": "4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4",
+ "startOffsets": "105,222,335,443,528,629,757,842,924,1016,1110,1208,1302,1403,1497,1593,1689,1781,1873,1955,2062,2162,2261,2369,2476,2583,2742,2842",
+ "endColumns": "116,112,107,84,100,127,84,81,91,93,97,93,100,93,95,95,91,91,81,106,99,98,107,106,106,158,99,81",
+ "endOffsets": "217,330,438,523,624,752,837,919,1011,1105,1203,1297,1398,1492,1588,1684,1776,1868,1950,2057,2157,2256,2364,2471,2578,2737,2837,2919"
+ }
+ }
+ ]
+ }
+ ]
+}
\ No newline at end of file
diff --git a/src/src/app/build/intermediates/blame/res/debug/multi-v2/values-et.json b/src/src/app/build/intermediates/blame/res/debug/multi-v2/values-et.json
new file mode 100644
index 0000000..49879f0
--- /dev/null
+++ b/src/src/app/build/intermediates/blame/res/debug/multi-v2/values-et.json
@@ -0,0 +1,36 @@
+{
+ "logs": [
+ {
+ "outputFile": "E:\\Note\\src\\app\\build\\intermediates\\incremental\\mergeDebugResources\\merged.dir\\values-et\\values-et.xml",
+ "map": [
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\88c548461109b0c917067cfea58751b3\\appcompat-1.0.0-alpha1\\res\\values-et\\values-et.xml",
+ "from": {
+ "startLines": "2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19,20,21,22,23,24,25,26,27,28,29",
+ "startColumns": "4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4",
+ "startOffsets": "105,222,329,440,526,628,745,825,903,995,1089,1194,1296,1406,1500,1601,1695,1787,1880,1963,2074,2179,2278,2388,2489,2592,2758,2860",
+ "endColumns": "116,106,110,85,101,116,79,77,91,93,104,101,109,93,100,93,91,92,82,110,104,98,109,100,102,165,101,81",
+ "endOffsets": "217,324,435,521,623,740,820,898,990,1084,1189,1291,1401,1495,1596,1690,1782,1875,1958,2069,2174,2273,2383,2484,2587,2753,2855,2937"
+ }
+ },
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\6d11613c3b6a00a9ea456b5609ec43f7\\core-1.0.0\\res\\values-et\\values-et.xml",
+ "from": {
+ "startLines": "2",
+ "startColumns": "4",
+ "startOffsets": "55",
+ "endColumns": "100",
+ "endOffsets": "151"
+ },
+ "to": {
+ "startLines": "30",
+ "startColumns": "4",
+ "startOffsets": "2942",
+ "endColumns": "100",
+ "endOffsets": "3038"
+ }
+ }
+ ]
+ }
+ ]
+}
\ No newline at end of file
diff --git a/src/src/app/build/intermediates/blame/res/debug/multi-v2/values-eu.json b/src/src/app/build/intermediates/blame/res/debug/multi-v2/values-eu.json
new file mode 100644
index 0000000..52a4a2e
--- /dev/null
+++ b/src/src/app/build/intermediates/blame/res/debug/multi-v2/values-eu.json
@@ -0,0 +1,36 @@
+{
+ "logs": [
+ {
+ "outputFile": "E:\\Note\\src\\app\\build\\intermediates\\incremental\\mergeDebugResources\\merged.dir\\values-eu\\values-eu.xml",
+ "map": [
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\6d11613c3b6a00a9ea456b5609ec43f7\\core-1.0.0\\res\\values-eu\\values-eu.xml",
+ "from": {
+ "startLines": "2",
+ "startColumns": "4",
+ "startOffsets": "55",
+ "endColumns": "100",
+ "endOffsets": "151"
+ },
+ "to": {
+ "startLines": "30",
+ "startColumns": "4",
+ "startOffsets": "2938",
+ "endColumns": "100",
+ "endOffsets": "3034"
+ }
+ },
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\88c548461109b0c917067cfea58751b3\\appcompat-1.0.0-alpha1\\res\\values-eu\\values-eu.xml",
+ "from": {
+ "startLines": "2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19,20,21,22,23,24,25,26,27,28,29",
+ "startColumns": "4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4",
+ "startOffsets": "105,214,312,422,508,614,738,825,909,1001,1095,1192,1286,1388,1482,1578,1675,1767,1860,1942,2051,2161,2260,2369,2475,2586,2757,2856",
+ "endColumns": "108,97,109,85,105,123,86,83,91,93,96,93,101,93,95,96,91,92,81,108,109,98,108,105,110,170,98,81",
+ "endOffsets": "209,307,417,503,609,733,820,904,996,1090,1187,1281,1383,1477,1573,1670,1762,1855,1937,2046,2156,2255,2364,2470,2581,2752,2851,2933"
+ }
+ }
+ ]
+ }
+ ]
+}
\ No newline at end of file
diff --git a/src/src/app/build/intermediates/blame/res/debug/multi-v2/values-fa.json b/src/src/app/build/intermediates/blame/res/debug/multi-v2/values-fa.json
new file mode 100644
index 0000000..fd876d5
--- /dev/null
+++ b/src/src/app/build/intermediates/blame/res/debug/multi-v2/values-fa.json
@@ -0,0 +1,36 @@
+{
+ "logs": [
+ {
+ "outputFile": "E:\\Note\\src\\app\\build\\intermediates\\incremental\\mergeDebugResources\\merged.dir\\values-fa\\values-fa.xml",
+ "map": [
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\6d11613c3b6a00a9ea456b5609ec43f7\\core-1.0.0\\res\\values-fa\\values-fa.xml",
+ "from": {
+ "startLines": "2",
+ "startColumns": "4",
+ "startOffsets": "55",
+ "endColumns": "100",
+ "endOffsets": "151"
+ },
+ "to": {
+ "startLines": "30",
+ "startColumns": "4",
+ "startOffsets": "2903",
+ "endColumns": "100",
+ "endOffsets": "2999"
+ }
+ },
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\88c548461109b0c917067cfea58751b3\\appcompat-1.0.0-alpha1\\res\\values-fa\\values-fa.xml",
+ "from": {
+ "startLines": "2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19,20,21,22,23,24,25,26,27,28,29",
+ "startColumns": "4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4",
+ "startOffsets": "105,215,318,429,513,616,731,810,888,981,1076,1172,1266,1369,1464,1561,1660,1753,1843,1924,2036,2139,2237,2347,2451,2560,2721,2822",
+ "endColumns": "109,102,110,83,102,114,78,77,92,94,95,93,102,94,96,98,92,89,80,111,102,97,109,103,108,160,100,80",
+ "endOffsets": "210,313,424,508,611,726,805,883,976,1071,1167,1261,1364,1459,1556,1655,1748,1838,1919,2031,2134,2232,2342,2446,2555,2716,2817,2898"
+ }
+ }
+ ]
+ }
+ ]
+}
\ No newline at end of file
diff --git a/src/src/app/build/intermediates/blame/res/debug/multi-v2/values-fi.json b/src/src/app/build/intermediates/blame/res/debug/multi-v2/values-fi.json
new file mode 100644
index 0000000..4c0b53e
--- /dev/null
+++ b/src/src/app/build/intermediates/blame/res/debug/multi-v2/values-fi.json
@@ -0,0 +1,36 @@
+{
+ "logs": [
+ {
+ "outputFile": "E:\\Note\\src\\app\\build\\intermediates\\incremental\\mergeDebugResources\\merged.dir\\values-fi\\values-fi.xml",
+ "map": [
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\88c548461109b0c917067cfea58751b3\\appcompat-1.0.0-alpha1\\res\\values-fi\\values-fi.xml",
+ "from": {
+ "startLines": "2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19,20,21,22,23,24,25,26,27,28,29",
+ "startColumns": "4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4",
+ "startOffsets": "105,213,313,414,500,605,723,810,892,983,1076,1172,1266,1361,1454,1550,1649,1740,1834,1914,2021,2124,2221,2327,2426,2530,2693,2792",
+ "endColumns": "107,99,100,85,104,117,86,81,90,92,95,93,94,92,95,98,90,93,79,106,102,96,105,98,103,162,98,79",
+ "endOffsets": "208,308,409,495,600,718,805,887,978,1071,1167,1261,1356,1449,1545,1644,1735,1829,1909,2016,2119,2216,2322,2421,2525,2688,2787,2867"
+ }
+ },
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\6d11613c3b6a00a9ea456b5609ec43f7\\core-1.0.0\\res\\values-fi\\values-fi.xml",
+ "from": {
+ "startLines": "2",
+ "startColumns": "4",
+ "startOffsets": "55",
+ "endColumns": "100",
+ "endOffsets": "151"
+ },
+ "to": {
+ "startLines": "30",
+ "startColumns": "4",
+ "startOffsets": "2872",
+ "endColumns": "100",
+ "endOffsets": "2968"
+ }
+ }
+ ]
+ }
+ ]
+}
\ No newline at end of file
diff --git a/src/src/app/build/intermediates/blame/res/debug/multi-v2/values-fr-rCA.json b/src/src/app/build/intermediates/blame/res/debug/multi-v2/values-fr-rCA.json
new file mode 100644
index 0000000..464922e
--- /dev/null
+++ b/src/src/app/build/intermediates/blame/res/debug/multi-v2/values-fr-rCA.json
@@ -0,0 +1,36 @@
+{
+ "logs": [
+ {
+ "outputFile": "E:\\Note\\src\\app\\build\\intermediates\\incremental\\mergeDebugResources\\merged.dir\\values-fr-rCA\\values-fr-rCA.xml",
+ "map": [
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\88c548461109b0c917067cfea58751b3\\appcompat-1.0.0-alpha1\\res\\values-fr-rCA\\values-fr-rCA.xml",
+ "from": {
+ "startLines": "2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19,20,21,22,23,24,25,26,27,28,29",
+ "startColumns": "4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4",
+ "startOffsets": "105,216,331,442,529,645,775,858,938,1029,1122,1221,1316,1417,1510,1603,1698,1789,1880,1976,2086,2198,2301,2412,2519,2621,2780,2879",
+ "endColumns": "110,114,110,86,115,129,82,79,90,92,98,94,100,92,92,94,90,90,95,109,111,102,110,106,101,158,98,85",
+ "endOffsets": "211,326,437,524,640,770,853,933,1024,1117,1216,1311,1412,1505,1598,1693,1784,1875,1971,2081,2193,2296,2407,2514,2616,2775,2874,2960"
+ }
+ },
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\6d11613c3b6a00a9ea456b5609ec43f7\\core-1.0.0\\res\\values-fr-rCA\\values-fr-rCA.xml",
+ "from": {
+ "startLines": "2",
+ "startColumns": "4",
+ "startOffsets": "55",
+ "endColumns": "100",
+ "endOffsets": "151"
+ },
+ "to": {
+ "startLines": "30",
+ "startColumns": "4",
+ "startOffsets": "2965",
+ "endColumns": "100",
+ "endOffsets": "3061"
+ }
+ }
+ ]
+ }
+ ]
+}
\ No newline at end of file
diff --git a/src/src/app/build/intermediates/blame/res/debug/multi-v2/values-fr.json b/src/src/app/build/intermediates/blame/res/debug/multi-v2/values-fr.json
new file mode 100644
index 0000000..237bbf0
--- /dev/null
+++ b/src/src/app/build/intermediates/blame/res/debug/multi-v2/values-fr.json
@@ -0,0 +1,36 @@
+{
+ "logs": [
+ {
+ "outputFile": "E:\\Note\\src\\app\\build\\intermediates\\incremental\\mergeDebugResources\\merged.dir\\values-fr\\values-fr.xml",
+ "map": [
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\88c548461109b0c917067cfea58751b3\\appcompat-1.0.0-alpha1\\res\\values-fr\\values-fr.xml",
+ "from": {
+ "startLines": "2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19,20,21,22,23,24,25,26,27,28,29",
+ "startColumns": "4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4",
+ "startOffsets": "105,216,331,442,524,630,760,843,923,1014,1107,1206,1301,1402,1495,1588,1683,1774,1865,1951,2061,2173,2276,2387,2494,2601,2760,2859",
+ "endColumns": "110,114,110,81,105,129,82,79,90,92,98,94,100,92,92,94,90,90,85,109,111,102,110,106,106,158,98,85",
+ "endOffsets": "211,326,437,519,625,755,838,918,1009,1102,1201,1296,1397,1490,1583,1678,1769,1860,1946,2056,2168,2271,2382,2489,2596,2755,2854,2940"
+ }
+ },
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\6d11613c3b6a00a9ea456b5609ec43f7\\core-1.0.0\\res\\values-fr\\values-fr.xml",
+ "from": {
+ "startLines": "2",
+ "startColumns": "4",
+ "startOffsets": "55",
+ "endColumns": "100",
+ "endOffsets": "151"
+ },
+ "to": {
+ "startLines": "30",
+ "startColumns": "4",
+ "startOffsets": "2945",
+ "endColumns": "100",
+ "endOffsets": "3041"
+ }
+ }
+ ]
+ }
+ ]
+}
\ No newline at end of file
diff --git a/src/src/app/build/intermediates/blame/res/debug/multi-v2/values-gl.json b/src/src/app/build/intermediates/blame/res/debug/multi-v2/values-gl.json
new file mode 100644
index 0000000..13c7635
--- /dev/null
+++ b/src/src/app/build/intermediates/blame/res/debug/multi-v2/values-gl.json
@@ -0,0 +1,36 @@
+{
+ "logs": [
+ {
+ "outputFile": "E:\\Note\\src\\app\\build\\intermediates\\incremental\\mergeDebugResources\\merged.dir\\values-gl\\values-gl.xml",
+ "map": [
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\6d11613c3b6a00a9ea456b5609ec43f7\\core-1.0.0\\res\\values-gl\\values-gl.xml",
+ "from": {
+ "startLines": "2",
+ "startColumns": "4",
+ "startOffsets": "55",
+ "endColumns": "100",
+ "endOffsets": "151"
+ },
+ "to": {
+ "startLines": "30",
+ "startColumns": "4",
+ "startOffsets": "2920",
+ "endColumns": "100",
+ "endOffsets": "3016"
+ }
+ },
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\88c548461109b0c917067cfea58751b3\\appcompat-1.0.0-alpha1\\res\\values-gl\\values-gl.xml",
+ "from": {
+ "startLines": "2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19,20,21,22,23,24,25,26,27,28,29",
+ "startColumns": "4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4",
+ "startOffsets": "105,217,329,437,522,624,750,834,915,1007,1101,1199,1293,1394,1488,1584,1679,1771,1863,1945,2052,2161,2260,2368,2472,2579,2738,2838",
+ "endColumns": "111,111,107,84,101,125,83,80,91,93,97,93,100,93,95,94,91,91,81,106,108,98,107,103,106,158,99,81",
+ "endOffsets": "212,324,432,517,619,745,829,910,1002,1096,1194,1288,1389,1483,1579,1674,1766,1858,1940,2047,2156,2255,2363,2467,2574,2733,2833,2915"
+ }
+ }
+ ]
+ }
+ ]
+}
\ No newline at end of file
diff --git a/src/src/app/build/intermediates/blame/res/debug/multi-v2/values-gu.json b/src/src/app/build/intermediates/blame/res/debug/multi-v2/values-gu.json
new file mode 100644
index 0000000..0075ab8
--- /dev/null
+++ b/src/src/app/build/intermediates/blame/res/debug/multi-v2/values-gu.json
@@ -0,0 +1,36 @@
+{
+ "logs": [
+ {
+ "outputFile": "E:\\Note\\src\\app\\build\\intermediates\\incremental\\mergeDebugResources\\merged.dir\\values-gu\\values-gu.xml",
+ "map": [
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\6d11613c3b6a00a9ea456b5609ec43f7\\core-1.0.0\\res\\values-gu\\values-gu.xml",
+ "from": {
+ "startLines": "2",
+ "startColumns": "4",
+ "startOffsets": "55",
+ "endColumns": "100",
+ "endOffsets": "151"
+ },
+ "to": {
+ "startLines": "30",
+ "startColumns": "4",
+ "startOffsets": "2882",
+ "endColumns": "100",
+ "endOffsets": "2978"
+ }
+ },
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\88c548461109b0c917067cfea58751b3\\appcompat-1.0.0-alpha1\\res\\values-gu\\values-gu.xml",
+ "from": {
+ "startLines": "2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19,20,21,22,23,24,25,26,27,28,29",
+ "startColumns": "4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4",
+ "startOffsets": "105,214,318,425,512,613,736,813,891,982,1075,1174,1268,1369,1462,1557,1654,1745,1836,1916,2022,2124,2221,2330,2429,2539,2699,2802",
+ "endColumns": "108,103,106,86,100,122,76,77,90,92,98,93,100,92,94,96,90,90,79,105,101,96,108,98,109,159,102,79",
+ "endOffsets": "209,313,420,507,608,731,808,886,977,1070,1169,1263,1364,1457,1552,1649,1740,1831,1911,2017,2119,2216,2325,2424,2534,2694,2797,2877"
+ }
+ }
+ ]
+ }
+ ]
+}
\ No newline at end of file
diff --git a/src/src/app/build/intermediates/blame/res/debug/multi-v2/values-h720dp-v13.json b/src/src/app/build/intermediates/blame/res/debug/multi-v2/values-h720dp-v13.json
new file mode 100644
index 0000000..a351af2
--- /dev/null
+++ b/src/src/app/build/intermediates/blame/res/debug/multi-v2/values-h720dp-v13.json
@@ -0,0 +1,19 @@
+{
+ "logs": [
+ {
+ "outputFile": "E:\\Note\\src\\app\\build\\intermediates\\incremental\\mergeDebugResources\\merged.dir\\values-h720dp-v13\\values-h720dp-v13.xml",
+ "map": [
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\88c548461109b0c917067cfea58751b3\\appcompat-1.0.0-alpha1\\res\\values-h720dp-v13\\values-h720dp-v13.xml",
+ "from": {
+ "startLines": "2",
+ "startColumns": "4",
+ "startOffsets": "55",
+ "endColumns": "66",
+ "endOffsets": "117"
+ }
+ }
+ ]
+ }
+ ]
+}
\ No newline at end of file
diff --git a/src/src/app/build/intermediates/blame/res/debug/multi-v2/values-hdpi-v4.json b/src/src/app/build/intermediates/blame/res/debug/multi-v2/values-hdpi-v4.json
new file mode 100644
index 0000000..62caa7a
--- /dev/null
+++ b/src/src/app/build/intermediates/blame/res/debug/multi-v2/values-hdpi-v4.json
@@ -0,0 +1,20 @@
+{
+ "logs": [
+ {
+ "outputFile": "E:\\Note\\src\\app\\build\\intermediates\\incremental\\mergeDebugResources\\merged.dir\\values-hdpi-v4\\values-hdpi-v4.xml",
+ "map": [
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\88c548461109b0c917067cfea58751b3\\appcompat-1.0.0-alpha1\\res\\values-hdpi-v4\\values-hdpi-v4.xml",
+ "from": {
+ "startLines": "2",
+ "startColumns": "4",
+ "startOffsets": "55",
+ "endLines": "6",
+ "endColumns": "13",
+ "endOffsets": "327"
+ }
+ }
+ ]
+ }
+ ]
+}
\ No newline at end of file
diff --git a/src/src/app/build/intermediates/blame/res/debug/multi-v2/values-hi.json b/src/src/app/build/intermediates/blame/res/debug/multi-v2/values-hi.json
new file mode 100644
index 0000000..6cce2ed
--- /dev/null
+++ b/src/src/app/build/intermediates/blame/res/debug/multi-v2/values-hi.json
@@ -0,0 +1,36 @@
+{
+ "logs": [
+ {
+ "outputFile": "E:\\Note\\src\\app\\build\\intermediates\\incremental\\mergeDebugResources\\merged.dir\\values-hi\\values-hi.xml",
+ "map": [
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\88c548461109b0c917067cfea58751b3\\appcompat-1.0.0-alpha1\\res\\values-hi\\values-hi.xml",
+ "from": {
+ "startLines": "2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19,20,21,22,23,24,25,26,27,28,29",
+ "startColumns": "4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4",
+ "startOffsets": "105,211,308,418,504,606,728,805,883,974,1067,1163,1257,1358,1451,1546,1640,1731,1822,1912,2021,2124,2226,2336,2437,2549,2711,2812",
+ "endColumns": "105,96,109,85,101,121,76,77,90,92,95,93,100,92,94,93,90,90,89,108,102,101,109,100,111,161,100,79",
+ "endOffsets": "206,303,413,499,601,723,800,878,969,1062,1158,1252,1353,1446,1541,1635,1726,1817,1907,2016,2119,2221,2331,2432,2544,2706,2807,2887"
+ }
+ },
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\6d11613c3b6a00a9ea456b5609ec43f7\\core-1.0.0\\res\\values-hi\\values-hi.xml",
+ "from": {
+ "startLines": "2",
+ "startColumns": "4",
+ "startOffsets": "55",
+ "endColumns": "100",
+ "endOffsets": "151"
+ },
+ "to": {
+ "startLines": "30",
+ "startColumns": "4",
+ "startOffsets": "2892",
+ "endColumns": "100",
+ "endOffsets": "2988"
+ }
+ }
+ ]
+ }
+ ]
+}
\ No newline at end of file
diff --git a/src/src/app/build/intermediates/blame/res/debug/multi-v2/values-hr.json b/src/src/app/build/intermediates/blame/res/debug/multi-v2/values-hr.json
new file mode 100644
index 0000000..74adada
--- /dev/null
+++ b/src/src/app/build/intermediates/blame/res/debug/multi-v2/values-hr.json
@@ -0,0 +1,36 @@
+{
+ "logs": [
+ {
+ "outputFile": "E:\\Note\\src\\app\\build\\intermediates\\incremental\\mergeDebugResources\\merged.dir\\values-hr\\values-hr.xml",
+ "map": [
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\6d11613c3b6a00a9ea456b5609ec43f7\\core-1.0.0\\res\\values-hr\\values-hr.xml",
+ "from": {
+ "startLines": "2",
+ "startColumns": "4",
+ "startOffsets": "55",
+ "endColumns": "100",
+ "endOffsets": "151"
+ },
+ "to": {
+ "startLines": "30",
+ "startColumns": "4",
+ "startOffsets": "2926",
+ "endColumns": "100",
+ "endOffsets": "3022"
+ }
+ },
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\88c548461109b0c917067cfea58751b3\\appcompat-1.0.0-alpha1\\res\\values-hr\\values-hr.xml",
+ "from": {
+ "startLines": "2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19,20,21,22,23,24,25,26,27,28,29",
+ "startColumns": "4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4",
+ "startOffsets": "105,210,307,417,503,607,726,810,893,984,1077,1173,1267,1368,1461,1556,1655,1746,1837,1923,2027,2140,2246,2351,2464,2571,2740,2837",
+ "endColumns": "104,96,109,85,103,118,83,82,90,92,95,93,100,92,94,98,90,90,85,103,112,105,104,112,106,168,96,88",
+ "endOffsets": "205,302,412,498,602,721,805,888,979,1072,1168,1262,1363,1456,1551,1650,1741,1832,1918,2022,2135,2241,2346,2459,2566,2735,2832,2921"
+ }
+ }
+ ]
+ }
+ ]
+}
\ No newline at end of file
diff --git a/src/src/app/build/intermediates/blame/res/debug/multi-v2/values-hu.json b/src/src/app/build/intermediates/blame/res/debug/multi-v2/values-hu.json
new file mode 100644
index 0000000..7cd87e6
--- /dev/null
+++ b/src/src/app/build/intermediates/blame/res/debug/multi-v2/values-hu.json
@@ -0,0 +1,36 @@
+{
+ "logs": [
+ {
+ "outputFile": "E:\\Note\\src\\app\\build\\intermediates\\incremental\\mergeDebugResources\\merged.dir\\values-hu\\values-hu.xml",
+ "map": [
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\6d11613c3b6a00a9ea456b5609ec43f7\\core-1.0.0\\res\\values-hu\\values-hu.xml",
+ "from": {
+ "startLines": "2",
+ "startColumns": "4",
+ "startOffsets": "55",
+ "endColumns": "100",
+ "endOffsets": "151"
+ },
+ "to": {
+ "startLines": "30",
+ "startColumns": "4",
+ "startOffsets": "2961",
+ "endColumns": "100",
+ "endOffsets": "3057"
+ }
+ },
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\88c548461109b0c917067cfea58751b3\\appcompat-1.0.0-alpha1\\res\\values-hu\\values-hu.xml",
+ "from": {
+ "startLines": "2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19,20,21,22,23,24,25,26,27,28,29",
+ "startColumns": "4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4",
+ "startOffsets": "105,213,318,433,517,629,759,835,911,1002,1095,1191,1285,1386,1479,1574,1669,1760,1851,1934,2044,2155,2255,2366,2474,2593,2775,2878",
+ "endColumns": "107,104,114,83,111,129,75,75,90,92,95,93,100,92,94,94,90,90,82,109,110,99,110,107,118,181,102,82",
+ "endOffsets": "208,313,428,512,624,754,830,906,997,1090,1186,1280,1381,1474,1569,1664,1755,1846,1929,2039,2150,2250,2361,2469,2588,2770,2873,2956"
+ }
+ }
+ ]
+ }
+ ]
+}
\ No newline at end of file
diff --git a/src/src/app/build/intermediates/blame/res/debug/multi-v2/values-hy.json b/src/src/app/build/intermediates/blame/res/debug/multi-v2/values-hy.json
new file mode 100644
index 0000000..fa61e55
--- /dev/null
+++ b/src/src/app/build/intermediates/blame/res/debug/multi-v2/values-hy.json
@@ -0,0 +1,36 @@
+{
+ "logs": [
+ {
+ "outputFile": "E:\\Note\\src\\app\\build\\intermediates\\incremental\\mergeDebugResources\\merged.dir\\values-hy\\values-hy.xml",
+ "map": [
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\6d11613c3b6a00a9ea456b5609ec43f7\\core-1.0.0\\res\\values-hy\\values-hy.xml",
+ "from": {
+ "startLines": "2",
+ "startColumns": "4",
+ "startOffsets": "55",
+ "endColumns": "100",
+ "endOffsets": "151"
+ },
+ "to": {
+ "startLines": "30",
+ "startColumns": "4",
+ "startOffsets": "2884",
+ "endColumns": "100",
+ "endOffsets": "2980"
+ }
+ },
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\88c548461109b0c917067cfea58751b3\\appcompat-1.0.0-alpha1\\res\\values-hy\\values-hy.xml",
+ "from": {
+ "startLines": "2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19,20,21,22,23,24,25,26,27,28,29",
+ "startColumns": "4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4",
+ "startOffsets": "105,208,309,419,508,614,729,811,892,983,1076,1172,1266,1367,1460,1555,1649,1740,1831,1916,2023,2130,2229,2339,2446,2546,2703,2802",
+ "endColumns": "102,100,109,88,105,114,81,80,90,92,95,93,100,92,94,93,90,90,84,106,106,98,109,106,99,156,98,81",
+ "endOffsets": "203,304,414,503,609,724,806,887,978,1071,1167,1261,1362,1455,1550,1644,1735,1826,1911,2018,2125,2224,2334,2441,2541,2698,2797,2879"
+ }
+ }
+ ]
+ }
+ ]
+}
\ No newline at end of file
diff --git a/src/src/app/build/intermediates/blame/res/debug/multi-v2/values-in.json b/src/src/app/build/intermediates/blame/res/debug/multi-v2/values-in.json
new file mode 100644
index 0000000..14811ae
--- /dev/null
+++ b/src/src/app/build/intermediates/blame/res/debug/multi-v2/values-in.json
@@ -0,0 +1,36 @@
+{
+ "logs": [
+ {
+ "outputFile": "E:\\Note\\src\\app\\build\\intermediates\\incremental\\mergeDebugResources\\merged.dir\\values-in\\values-in.xml",
+ "map": [
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\6d11613c3b6a00a9ea456b5609ec43f7\\core-1.0.0\\res\\values-in\\values-in.xml",
+ "from": {
+ "startLines": "2",
+ "startColumns": "4",
+ "startOffsets": "55",
+ "endColumns": "100",
+ "endOffsets": "151"
+ },
+ "to": {
+ "startLines": "30",
+ "startColumns": "4",
+ "startOffsets": "2887",
+ "endColumns": "100",
+ "endOffsets": "2983"
+ }
+ },
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\88c548461109b0c917067cfea58751b3\\appcompat-1.0.0-alpha1\\res\\values-in\\values-in.xml",
+ "from": {
+ "startLines": "2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19,20,21,22,23,24,25,26,27,28,29",
+ "startColumns": "4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4",
+ "startOffsets": "105,215,317,422,509,613,729,811,890,981,1074,1170,1264,1365,1458,1553,1647,1738,1829,1915,2018,2127,2228,2332,2440,2548,2704,2803",
+ "endColumns": "109,101,104,86,103,115,81,78,90,92,95,93,100,92,94,93,90,90,85,102,108,100,103,107,107,155,98,83",
+ "endOffsets": "210,312,417,504,608,724,806,885,976,1069,1165,1259,1360,1453,1548,1642,1733,1824,1910,2013,2122,2223,2327,2435,2543,2699,2798,2882"
+ }
+ }
+ ]
+ }
+ ]
+}
\ No newline at end of file
diff --git a/src/src/app/build/intermediates/blame/res/debug/multi-v2/values-is.json b/src/src/app/build/intermediates/blame/res/debug/multi-v2/values-is.json
new file mode 100644
index 0000000..4b3dd2e
--- /dev/null
+++ b/src/src/app/build/intermediates/blame/res/debug/multi-v2/values-is.json
@@ -0,0 +1,36 @@
+{
+ "logs": [
+ {
+ "outputFile": "E:\\Note\\src\\app\\build\\intermediates\\incremental\\mergeDebugResources\\merged.dir\\values-is\\values-is.xml",
+ "map": [
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\6d11613c3b6a00a9ea456b5609ec43f7\\core-1.0.0\\res\\values-is\\values-is.xml",
+ "from": {
+ "startLines": "2",
+ "startColumns": "4",
+ "startOffsets": "55",
+ "endColumns": "100",
+ "endOffsets": "151"
+ },
+ "to": {
+ "startLines": "30",
+ "startColumns": "4",
+ "startOffsets": "2865",
+ "endColumns": "100",
+ "endOffsets": "2961"
+ }
+ },
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\88c548461109b0c917067cfea58751b3\\appcompat-1.0.0-alpha1\\res\\values-is\\values-is.xml",
+ "from": {
+ "startLines": "2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19,20,21,22,23,24,25,26,27,28,29",
+ "startColumns": "4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4",
+ "startOffsets": "105,205,302,414,499,600,714,794,874,965,1058,1154,1248,1355,1448,1543,1638,1729,1823,1904,2014,2122,2220,2329,2428,2531,2686,2784",
+ "endColumns": "99,96,111,84,100,113,79,79,90,92,95,93,106,92,94,94,90,93,80,109,107,97,108,98,102,154,97,80",
+ "endOffsets": "200,297,409,494,595,709,789,869,960,1053,1149,1243,1350,1443,1538,1633,1724,1818,1899,2009,2117,2215,2324,2423,2526,2681,2779,2860"
+ }
+ }
+ ]
+ }
+ ]
+}
\ No newline at end of file
diff --git a/src/src/app/build/intermediates/blame/res/debug/multi-v2/values-it.json b/src/src/app/build/intermediates/blame/res/debug/multi-v2/values-it.json
new file mode 100644
index 0000000..a5d9bd4
--- /dev/null
+++ b/src/src/app/build/intermediates/blame/res/debug/multi-v2/values-it.json
@@ -0,0 +1,36 @@
+{
+ "logs": [
+ {
+ "outputFile": "E:\\Note\\src\\app\\build\\intermediates\\incremental\\mergeDebugResources\\merged.dir\\values-it\\values-it.xml",
+ "map": [
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\6d11613c3b6a00a9ea456b5609ec43f7\\core-1.0.0\\res\\values-it\\values-it.xml",
+ "from": {
+ "startLines": "2",
+ "startColumns": "4",
+ "startOffsets": "55",
+ "endColumns": "100",
+ "endOffsets": "151"
+ },
+ "to": {
+ "startLines": "30",
+ "startColumns": "4",
+ "startOffsets": "2906",
+ "endColumns": "100",
+ "endOffsets": "3002"
+ }
+ },
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\88c548461109b0c917067cfea58751b3\\appcompat-1.0.0-alpha1\\res\\values-it\\values-it.xml",
+ "from": {
+ "startLines": "2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19,20,21,22,23,24,25,26,27,28,29",
+ "startColumns": "4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4",
+ "startOffsets": "105,214,314,423,507,616,741,818,894,986,1080,1174,1268,1370,1464,1561,1667,1759,1851,1932,2038,2146,2244,2348,2453,2560,2723,2823",
+ "endColumns": "108,99,108,83,108,124,76,75,91,93,93,93,101,93,96,105,91,91,80,105,107,97,103,104,106,162,99,82",
+ "endOffsets": "209,309,418,502,611,736,813,889,981,1075,1169,1263,1365,1459,1556,1662,1754,1846,1927,2033,2141,2239,2343,2448,2555,2718,2818,2901"
+ }
+ }
+ ]
+ }
+ ]
+}
\ No newline at end of file
diff --git a/src/src/app/build/intermediates/blame/res/debug/multi-v2/values-iw.json b/src/src/app/build/intermediates/blame/res/debug/multi-v2/values-iw.json
new file mode 100644
index 0000000..ff990d9
--- /dev/null
+++ b/src/src/app/build/intermediates/blame/res/debug/multi-v2/values-iw.json
@@ -0,0 +1,36 @@
+{
+ "logs": [
+ {
+ "outputFile": "E:\\Note\\src\\app\\build\\intermediates\\incremental\\mergeDebugResources\\merged.dir\\values-iw\\values-iw.xml",
+ "map": [
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\6d11613c3b6a00a9ea456b5609ec43f7\\core-1.0.0\\res\\values-iw\\values-iw.xml",
+ "from": {
+ "startLines": "2",
+ "startColumns": "4",
+ "startOffsets": "55",
+ "endColumns": "100",
+ "endOffsets": "151"
+ },
+ "to": {
+ "startLines": "30",
+ "startColumns": "4",
+ "startOffsets": "2832",
+ "endColumns": "100",
+ "endOffsets": "2928"
+ }
+ },
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\88c548461109b0c917067cfea58751b3\\appcompat-1.0.0-alpha1\\res\\values-iw\\values-iw.xml",
+ "from": {
+ "startLines": "2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19,20,21,22,23,24,25,26,27,28,29",
+ "startColumns": "4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4",
+ "startOffsets": "105,209,308,416,500,600,714,792,870,961,1055,1151,1245,1346,1439,1534,1631,1722,1814,1895,1997,2101,2199,2302,2403,2503,2655,2751",
+ "endColumns": "103,98,107,83,99,113,77,77,90,93,95,93,100,92,94,96,90,91,80,101,103,97,102,100,99,151,95,80",
+ "endOffsets": "204,303,411,495,595,709,787,865,956,1050,1146,1240,1341,1434,1529,1626,1717,1809,1890,1992,2096,2194,2297,2398,2498,2650,2746,2827"
+ }
+ }
+ ]
+ }
+ ]
+}
\ No newline at end of file
diff --git a/src/src/app/build/intermediates/blame/res/debug/multi-v2/values-ja.json b/src/src/app/build/intermediates/blame/res/debug/multi-v2/values-ja.json
new file mode 100644
index 0000000..162b473
--- /dev/null
+++ b/src/src/app/build/intermediates/blame/res/debug/multi-v2/values-ja.json
@@ -0,0 +1,36 @@
+{
+ "logs": [
+ {
+ "outputFile": "E:\\Note\\src\\app\\build\\intermediates\\incremental\\mergeDebugResources\\merged.dir\\values-ja\\values-ja.xml",
+ "map": [
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\88c548461109b0c917067cfea58751b3\\appcompat-1.0.0-alpha1\\res\\values-ja\\values-ja.xml",
+ "from": {
+ "startLines": "2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19,20,21,22,23,24,25,26,27,28,29",
+ "startColumns": "4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4",
+ "startOffsets": "105,202,295,400,482,580,688,765,841,932,1025,1121,1215,1316,1409,1504,1598,1689,1780,1858,1960,2059,2154,2257,2352,2448,2596,2693",
+ "endColumns": "96,92,104,81,97,107,76,75,90,92,95,93,100,92,94,93,90,90,77,101,98,94,102,94,95,147,96,77",
+ "endOffsets": "197,290,395,477,575,683,760,836,927,1020,1116,1210,1311,1404,1499,1593,1684,1775,1853,1955,2054,2149,2252,2347,2443,2591,2688,2766"
+ }
+ },
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\6d11613c3b6a00a9ea456b5609ec43f7\\core-1.0.0\\res\\values-ja\\values-ja.xml",
+ "from": {
+ "startLines": "2",
+ "startColumns": "4",
+ "startOffsets": "55",
+ "endColumns": "100",
+ "endOffsets": "151"
+ },
+ "to": {
+ "startLines": "30",
+ "startColumns": "4",
+ "startOffsets": "2771",
+ "endColumns": "100",
+ "endOffsets": "2867"
+ }
+ }
+ ]
+ }
+ ]
+}
\ No newline at end of file
diff --git a/src/src/app/build/intermediates/blame/res/debug/multi-v2/values-ka.json b/src/src/app/build/intermediates/blame/res/debug/multi-v2/values-ka.json
new file mode 100644
index 0000000..73ef35d
--- /dev/null
+++ b/src/src/app/build/intermediates/blame/res/debug/multi-v2/values-ka.json
@@ -0,0 +1,36 @@
+{
+ "logs": [
+ {
+ "outputFile": "E:\\Note\\src\\app\\build\\intermediates\\incremental\\mergeDebugResources\\merged.dir\\values-ka\\values-ka.xml",
+ "map": [
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\6d11613c3b6a00a9ea456b5609ec43f7\\core-1.0.0\\res\\values-ka\\values-ka.xml",
+ "from": {
+ "startLines": "2",
+ "startColumns": "4",
+ "startOffsets": "55",
+ "endColumns": "100",
+ "endOffsets": "151"
+ },
+ "to": {
+ "startLines": "30",
+ "startColumns": "4",
+ "startOffsets": "2899",
+ "endColumns": "100",
+ "endOffsets": "2995"
+ }
+ },
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\88c548461109b0c917067cfea58751b3\\appcompat-1.0.0-alpha1\\res\\values-ka\\values-ka.xml",
+ "from": {
+ "startLines": "2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19,20,21,22,23,24,25,26,27,28,29",
+ "startColumns": "4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4",
+ "startOffsets": "105,214,318,429,517,622,735,819,901,992,1085,1180,1276,1377,1470,1565,1659,1750,1841,1924,2037,2144,2242,2355,2459,2563,2720,2818",
+ "endColumns": "108,103,110,87,104,112,83,81,90,92,94,95,100,92,94,93,90,90,82,112,106,97,112,103,103,156,97,80",
+ "endOffsets": "209,313,424,512,617,730,814,896,987,1080,1175,1271,1372,1465,1560,1654,1745,1836,1919,2032,2139,2237,2350,2454,2558,2715,2813,2894"
+ }
+ }
+ ]
+ }
+ ]
+}
\ No newline at end of file
diff --git a/src/src/app/build/intermediates/blame/res/debug/multi-v2/values-kk.json b/src/src/app/build/intermediates/blame/res/debug/multi-v2/values-kk.json
new file mode 100644
index 0000000..d08b5f4
--- /dev/null
+++ b/src/src/app/build/intermediates/blame/res/debug/multi-v2/values-kk.json
@@ -0,0 +1,36 @@
+{
+ "logs": [
+ {
+ "outputFile": "E:\\Note\\src\\app\\build\\intermediates\\incremental\\mergeDebugResources\\merged.dir\\values-kk\\values-kk.xml",
+ "map": [
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\6d11613c3b6a00a9ea456b5609ec43f7\\core-1.0.0\\res\\values-kk\\values-kk.xml",
+ "from": {
+ "startLines": "2",
+ "startColumns": "4",
+ "startOffsets": "55",
+ "endColumns": "100",
+ "endOffsets": "151"
+ },
+ "to": {
+ "startLines": "30",
+ "startColumns": "4",
+ "startOffsets": "2893",
+ "endColumns": "100",
+ "endOffsets": "2989"
+ }
+ },
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\88c548461109b0c917067cfea58751b3\\appcompat-1.0.0-alpha1\\res\\values-kk\\values-kk.xml",
+ "from": {
+ "startLines": "2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19,20,21,22,23,24,25,26,27,28,29",
+ "startColumns": "4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4",
+ "startOffsets": "105,217,320,430,515,621,740,821,901,992,1085,1181,1275,1376,1469,1564,1661,1752,1844,1925,2028,2133,2231,2338,2447,2547,2713,2812",
+ "endColumns": "111,102,109,84,105,118,80,79,90,92,95,93,100,92,94,96,90,91,80,102,104,97,106,108,99,165,98,80",
+ "endOffsets": "212,315,425,510,616,735,816,896,987,1080,1176,1270,1371,1464,1559,1656,1747,1839,1920,2023,2128,2226,2333,2442,2542,2708,2807,2888"
+ }
+ }
+ ]
+ }
+ ]
+}
\ No newline at end of file
diff --git a/src/src/app/build/intermediates/blame/res/debug/multi-v2/values-km.json b/src/src/app/build/intermediates/blame/res/debug/multi-v2/values-km.json
new file mode 100644
index 0000000..bde54ef
--- /dev/null
+++ b/src/src/app/build/intermediates/blame/res/debug/multi-v2/values-km.json
@@ -0,0 +1,36 @@
+{
+ "logs": [
+ {
+ "outputFile": "E:\\Note\\src\\app\\build\\intermediates\\incremental\\mergeDebugResources\\merged.dir\\values-km\\values-km.xml",
+ "map": [
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\6d11613c3b6a00a9ea456b5609ec43f7\\core-1.0.0\\res\\values-km\\values-km.xml",
+ "from": {
+ "startLines": "2",
+ "startColumns": "4",
+ "startOffsets": "55",
+ "endColumns": "100",
+ "endOffsets": "151"
+ },
+ "to": {
+ "startLines": "30",
+ "startColumns": "4",
+ "startOffsets": "2882",
+ "endColumns": "100",
+ "endOffsets": "2978"
+ }
+ },
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\88c548461109b0c917067cfea58751b3\\appcompat-1.0.0-alpha1\\res\\values-km\\values-km.xml",
+ "from": {
+ "startLines": "2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19,20,21,22,23,24,25,26,27,28,29",
+ "startColumns": "4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4",
+ "startOffsets": "105,208,308,420,507,611,729,806,883,974,1067,1163,1257,1358,1451,1546,1640,1731,1822,1905,2009,2114,2214,2324,2431,2539,2701,2799",
+ "endColumns": "102,99,111,86,103,117,76,76,90,92,95,93,100,92,94,93,90,90,82,103,104,99,109,106,107,161,97,82",
+ "endOffsets": "203,303,415,502,606,724,801,878,969,1062,1158,1252,1353,1446,1541,1635,1726,1817,1900,2004,2109,2209,2319,2426,2534,2696,2794,2877"
+ }
+ }
+ ]
+ }
+ ]
+}
\ No newline at end of file
diff --git a/src/src/app/build/intermediates/blame/res/debug/multi-v2/values-kn.json b/src/src/app/build/intermediates/blame/res/debug/multi-v2/values-kn.json
new file mode 100644
index 0000000..ddc9a9f
--- /dev/null
+++ b/src/src/app/build/intermediates/blame/res/debug/multi-v2/values-kn.json
@@ -0,0 +1,36 @@
+{
+ "logs": [
+ {
+ "outputFile": "E:\\Note\\src\\app\\build\\intermediates\\incremental\\mergeDebugResources\\merged.dir\\values-kn\\values-kn.xml",
+ "map": [
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\88c548461109b0c917067cfea58751b3\\appcompat-1.0.0-alpha1\\res\\values-kn\\values-kn.xml",
+ "from": {
+ "startLines": "2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19,20,21,22,23,24,25,26,27,28,29",
+ "startColumns": "4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4",
+ "startOffsets": "105,223,335,448,536,643,770,847,924,1015,1108,1204,1298,1399,1492,1587,1681,1772,1863,1945,2061,2172,2271,2384,2488,2602,2766,2866",
+ "endColumns": "117,111,112,87,106,126,76,76,90,92,95,93,100,92,94,93,90,90,81,115,110,98,112,103,113,163,99,81",
+ "endOffsets": "218,330,443,531,638,765,842,919,1010,1103,1199,1293,1394,1487,1582,1676,1767,1858,1940,2056,2167,2266,2379,2483,2597,2761,2861,2943"
+ }
+ },
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\6d11613c3b6a00a9ea456b5609ec43f7\\core-1.0.0\\res\\values-kn\\values-kn.xml",
+ "from": {
+ "startLines": "2",
+ "startColumns": "4",
+ "startOffsets": "55",
+ "endColumns": "100",
+ "endOffsets": "151"
+ },
+ "to": {
+ "startLines": "30",
+ "startColumns": "4",
+ "startOffsets": "2948",
+ "endColumns": "100",
+ "endOffsets": "3044"
+ }
+ }
+ ]
+ }
+ ]
+}
\ No newline at end of file
diff --git a/src/src/app/build/intermediates/blame/res/debug/multi-v2/values-ko.json b/src/src/app/build/intermediates/blame/res/debug/multi-v2/values-ko.json
new file mode 100644
index 0000000..a2cf6b5
--- /dev/null
+++ b/src/src/app/build/intermediates/blame/res/debug/multi-v2/values-ko.json
@@ -0,0 +1,36 @@
+{
+ "logs": [
+ {
+ "outputFile": "E:\\Note\\src\\app\\build\\intermediates\\incremental\\mergeDebugResources\\merged.dir\\values-ko\\values-ko.xml",
+ "map": [
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\6d11613c3b6a00a9ea456b5609ec43f7\\core-1.0.0\\res\\values-ko\\values-ko.xml",
+ "from": {
+ "startLines": "2",
+ "startColumns": "4",
+ "startOffsets": "55",
+ "endColumns": "100",
+ "endOffsets": "151"
+ },
+ "to": {
+ "startLines": "30",
+ "startColumns": "4",
+ "startOffsets": "2756",
+ "endColumns": "100",
+ "endOffsets": "2852"
+ }
+ },
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\88c548461109b0c917067cfea58751b3\\appcompat-1.0.0-alpha1\\res\\values-ko\\values-ko.xml",
+ "from": {
+ "startLines": "2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19,20,21,22,23,24,25,26,27,28,29",
+ "startColumns": "4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4",
+ "startOffsets": "105,200,294,396,478,576,682,761,837,928,1021,1113,1204,1305,1398,1493,1587,1678,1769,1849,1947,2042,2137,2237,2333,2432,2584,2678",
+ "endColumns": "94,93,101,81,97,105,78,75,90,92,91,90,100,92,94,93,90,90,79,97,94,94,99,95,98,151,93,77",
+ "endOffsets": "195,289,391,473,571,677,756,832,923,1016,1108,1199,1300,1393,1488,1582,1673,1764,1844,1942,2037,2132,2232,2328,2427,2579,2673,2751"
+ }
+ }
+ ]
+ }
+ ]
+}
\ No newline at end of file
diff --git a/src/src/app/build/intermediates/blame/res/debug/multi-v2/values-ky.json b/src/src/app/build/intermediates/blame/res/debug/multi-v2/values-ky.json
new file mode 100644
index 0000000..884db69
--- /dev/null
+++ b/src/src/app/build/intermediates/blame/res/debug/multi-v2/values-ky.json
@@ -0,0 +1,36 @@
+{
+ "logs": [
+ {
+ "outputFile": "E:\\Note\\src\\app\\build\\intermediates\\incremental\\mergeDebugResources\\merged.dir\\values-ky\\values-ky.xml",
+ "map": [
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\6d11613c3b6a00a9ea456b5609ec43f7\\core-1.0.0\\res\\values-ky\\values-ky.xml",
+ "from": {
+ "startLines": "2",
+ "startColumns": "4",
+ "startOffsets": "55",
+ "endColumns": "100",
+ "endOffsets": "151"
+ },
+ "to": {
+ "startLines": "30",
+ "startColumns": "4",
+ "startOffsets": "2883",
+ "endColumns": "100",
+ "endOffsets": "2979"
+ }
+ },
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\88c548461109b0c917067cfea58751b3\\appcompat-1.0.0-alpha1\\res\\values-ky\\values-ky.xml",
+ "from": {
+ "startLines": "2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19,20,21,22,23,24,25,26,27,28,29",
+ "startColumns": "4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4",
+ "startOffsets": "105,209,304,423,507,614,731,809,888,979,1072,1168,1262,1363,1456,1551,1646,1737,1828,1909,2019,2126,2224,2330,2437,2538,2699,2802",
+ "endColumns": "103,94,118,83,106,116,77,78,90,92,95,93,100,92,94,94,90,90,80,109,106,97,105,106,100,160,102,80",
+ "endOffsets": "204,299,418,502,609,726,804,883,974,1067,1163,1257,1358,1451,1546,1641,1732,1823,1904,2014,2121,2219,2325,2432,2533,2694,2797,2878"
+ }
+ }
+ ]
+ }
+ ]
+}
\ No newline at end of file
diff --git a/src/src/app/build/intermediates/blame/res/debug/multi-v2/values-land.json b/src/src/app/build/intermediates/blame/res/debug/multi-v2/values-land.json
new file mode 100644
index 0000000..34624b3
--- /dev/null
+++ b/src/src/app/build/intermediates/blame/res/debug/multi-v2/values-land.json
@@ -0,0 +1,19 @@
+{
+ "logs": [
+ {
+ "outputFile": "E:\\Note\\src\\app\\build\\intermediates\\incremental\\mergeDebugResources\\merged.dir\\values-land\\values-land.xml",
+ "map": [
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\88c548461109b0c917067cfea58751b3\\appcompat-1.0.0-alpha1\\res\\values-land\\values-land.xml",
+ "from": {
+ "startLines": "2,3,4",
+ "startColumns": "4,4,4",
+ "startOffsets": "55,125,196",
+ "endColumns": "69,70,67",
+ "endOffsets": "120,191,259"
+ }
+ }
+ ]
+ }
+ ]
+}
\ No newline at end of file
diff --git a/src/src/app/build/intermediates/blame/res/debug/multi-v2/values-large-v4.json b/src/src/app/build/intermediates/blame/res/debug/multi-v2/values-large-v4.json
new file mode 100644
index 0000000..d3a7408
--- /dev/null
+++ b/src/src/app/build/intermediates/blame/res/debug/multi-v2/values-large-v4.json
@@ -0,0 +1,19 @@
+{
+ "logs": [
+ {
+ "outputFile": "E:\\Note\\src\\app\\build\\intermediates\\incremental\\mergeDebugResources\\merged.dir\\values-large-v4\\values-large-v4.xml",
+ "map": [
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\88c548461109b0c917067cfea58751b3\\appcompat-1.0.0-alpha1\\res\\values-large-v4\\values-large-v4.xml",
+ "from": {
+ "startLines": "2,3,4,5,6,7,8,9,10",
+ "startColumns": "4,4,4,4,4,4,4,4,4",
+ "startOffsets": "55,114,185,256,326,396,464,532,636",
+ "endColumns": "58,70,70,69,69,67,67,103,115",
+ "endOffsets": "109,180,251,321,391,459,527,631,747"
+ }
+ }
+ ]
+ }
+ ]
+}
\ No newline at end of file
diff --git a/src/src/app/build/intermediates/blame/res/debug/multi-v2/values-ldltr-v21.json b/src/src/app/build/intermediates/blame/res/debug/multi-v2/values-ldltr-v21.json
new file mode 100644
index 0000000..d347c7e
--- /dev/null
+++ b/src/src/app/build/intermediates/blame/res/debug/multi-v2/values-ldltr-v21.json
@@ -0,0 +1,19 @@
+{
+ "logs": [
+ {
+ "outputFile": "E:\\Note\\src\\app\\build\\intermediates\\incremental\\mergeDebugResources\\merged.dir\\values-ldltr-v21\\values-ldltr-v21.xml",
+ "map": [
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\88c548461109b0c917067cfea58751b3\\appcompat-1.0.0-alpha1\\res\\values-ldltr-v21\\values-ldltr-v21.xml",
+ "from": {
+ "startLines": "2",
+ "startColumns": "4",
+ "startOffsets": "55",
+ "endColumns": "112",
+ "endOffsets": "163"
+ }
+ }
+ ]
+ }
+ ]
+}
\ No newline at end of file
diff --git a/src/src/app/build/intermediates/blame/res/debug/multi-v2/values-lo.json b/src/src/app/build/intermediates/blame/res/debug/multi-v2/values-lo.json
new file mode 100644
index 0000000..205f3cd
--- /dev/null
+++ b/src/src/app/build/intermediates/blame/res/debug/multi-v2/values-lo.json
@@ -0,0 +1,36 @@
+{
+ "logs": [
+ {
+ "outputFile": "E:\\Note\\src\\app\\build\\intermediates\\incremental\\mergeDebugResources\\merged.dir\\values-lo\\values-lo.xml",
+ "map": [
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\6d11613c3b6a00a9ea456b5609ec43f7\\core-1.0.0\\res\\values-lo\\values-lo.xml",
+ "from": {
+ "startLines": "2",
+ "startColumns": "4",
+ "startOffsets": "55",
+ "endColumns": "100",
+ "endOffsets": "151"
+ },
+ "to": {
+ "startLines": "30",
+ "startColumns": "4",
+ "startOffsets": "2836",
+ "endColumns": "100",
+ "endOffsets": "2932"
+ }
+ },
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\88c548461109b0c917067cfea58751b3\\appcompat-1.0.0-alpha1\\res\\values-lo\\values-lo.xml",
+ "from": {
+ "startLines": "2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19,20,21,22,23,24,25,26,27,28,29",
+ "startColumns": "4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4",
+ "startOffsets": "105,208,305,412,497,602,714,791,869,960,1053,1149,1243,1344,1437,1532,1626,1717,1808,1888,1995,2092,2190,2295,2398,2502,2659,2755",
+ "endColumns": "102,96,106,84,104,111,76,77,90,92,95,93,100,92,94,93,90,90,79,106,96,97,104,102,103,156,95,80",
+ "endOffsets": "203,300,407,492,597,709,786,864,955,1048,1144,1238,1339,1432,1527,1621,1712,1803,1883,1990,2087,2185,2290,2393,2497,2654,2750,2831"
+ }
+ }
+ ]
+ }
+ ]
+}
\ No newline at end of file
diff --git a/src/src/app/build/intermediates/blame/res/debug/multi-v2/values-lt.json b/src/src/app/build/intermediates/blame/res/debug/multi-v2/values-lt.json
new file mode 100644
index 0000000..5e418d3
--- /dev/null
+++ b/src/src/app/build/intermediates/blame/res/debug/multi-v2/values-lt.json
@@ -0,0 +1,36 @@
+{
+ "logs": [
+ {
+ "outputFile": "E:\\Note\\src\\app\\build\\intermediates\\incremental\\mergeDebugResources\\merged.dir\\values-lt\\values-lt.xml",
+ "map": [
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\88c548461109b0c917067cfea58751b3\\appcompat-1.0.0-alpha1\\res\\values-lt\\values-lt.xml",
+ "from": {
+ "startLines": "2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19,20,21,22,23,24,25,26,27,28,29",
+ "startColumns": "4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4",
+ "startOffsets": "105,221,322,435,522,631,752,834,915,1009,1105,1203,1299,1403,1499,1597,1700,1794,1888,1973,2082,2191,2291,2401,2505,2618,2794,2895",
+ "endColumns": "115,100,112,86,108,120,81,80,93,95,97,95,103,95,97,102,93,93,84,108,108,99,109,103,112,175,100,82",
+ "endOffsets": "216,317,430,517,626,747,829,910,1004,1100,1198,1294,1398,1494,1592,1695,1789,1883,1968,2077,2186,2286,2396,2500,2613,2789,2890,2973"
+ }
+ },
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\6d11613c3b6a00a9ea456b5609ec43f7\\core-1.0.0\\res\\values-lt\\values-lt.xml",
+ "from": {
+ "startLines": "2",
+ "startColumns": "4",
+ "startOffsets": "55",
+ "endColumns": "100",
+ "endOffsets": "151"
+ },
+ "to": {
+ "startLines": "30",
+ "startColumns": "4",
+ "startOffsets": "2978",
+ "endColumns": "100",
+ "endOffsets": "3074"
+ }
+ }
+ ]
+ }
+ ]
+}
\ No newline at end of file
diff --git a/src/src/app/build/intermediates/blame/res/debug/multi-v2/values-lv.json b/src/src/app/build/intermediates/blame/res/debug/multi-v2/values-lv.json
new file mode 100644
index 0000000..82ea9d7
--- /dev/null
+++ b/src/src/app/build/intermediates/blame/res/debug/multi-v2/values-lv.json
@@ -0,0 +1,36 @@
+{
+ "logs": [
+ {
+ "outputFile": "E:\\Note\\src\\app\\build\\intermediates\\incremental\\mergeDebugResources\\merged.dir\\values-lv\\values-lv.xml",
+ "map": [
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\6d11613c3b6a00a9ea456b5609ec43f7\\core-1.0.0\\res\\values-lv\\values-lv.xml",
+ "from": {
+ "startLines": "2",
+ "startColumns": "4",
+ "startOffsets": "55",
+ "endColumns": "100",
+ "endOffsets": "151"
+ },
+ "to": {
+ "startLines": "30",
+ "startColumns": "4",
+ "startOffsets": "3076",
+ "endColumns": "100",
+ "endOffsets": "3172"
+ }
+ },
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\88c548461109b0c917067cfea58751b3\\appcompat-1.0.0-alpha1\\res\\values-lv\\values-lv.xml",
+ "from": {
+ "startLines": "2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19,20,21,22,23,24,25,26,27,28,29",
+ "startColumns": "4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4",
+ "startOffsets": "105,225,333,442,528,632,754,836,918,1028,1136,1243,1352,1464,1567,1679,1786,1891,1991,2076,2185,2297,2396,2507,2616,2721,2895,2994",
+ "endColumns": "119,107,108,85,103,121,81,81,109,107,106,108,111,102,111,106,104,99,84,108,111,98,110,108,104,173,98,81",
+ "endOffsets": "220,328,437,523,627,749,831,913,1023,1131,1238,1347,1459,1562,1674,1781,1886,1986,2071,2180,2292,2391,2502,2611,2716,2890,2989,3071"
+ }
+ }
+ ]
+ }
+ ]
+}
\ No newline at end of file
diff --git a/src/src/app/build/intermediates/blame/res/debug/multi-v2/values-mk.json b/src/src/app/build/intermediates/blame/res/debug/multi-v2/values-mk.json
new file mode 100644
index 0000000..bc8ffd6
--- /dev/null
+++ b/src/src/app/build/intermediates/blame/res/debug/multi-v2/values-mk.json
@@ -0,0 +1,36 @@
+{
+ "logs": [
+ {
+ "outputFile": "E:\\Note\\src\\app\\build\\intermediates\\incremental\\mergeDebugResources\\merged.dir\\values-mk\\values-mk.xml",
+ "map": [
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\6d11613c3b6a00a9ea456b5609ec43f7\\core-1.0.0\\res\\values-mk\\values-mk.xml",
+ "from": {
+ "startLines": "2",
+ "startColumns": "4",
+ "startOffsets": "55",
+ "endColumns": "100",
+ "endOffsets": "151"
+ },
+ "to": {
+ "startLines": "30",
+ "startColumns": "4",
+ "startOffsets": "2945",
+ "endColumns": "100",
+ "endOffsets": "3041"
+ }
+ },
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\88c548461109b0c917067cfea58751b3\\appcompat-1.0.0-alpha1\\res\\values-mk\\values-mk.xml",
+ "from": {
+ "startLines": "2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19,20,21,22,23,24,25,26,27,28,29",
+ "startColumns": "4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4",
+ "startOffsets": "105,213,317,425,511,616,735,818,900,997,1096,1193,1293,1400,1499,1600,1696,1793,1884,1971,2077,2184,2285,2392,2503,2607,2763,2861",
+ "endColumns": "107,103,107,85,104,118,82,81,96,98,96,99,106,98,100,95,96,90,86,105,106,100,106,110,103,155,97,83",
+ "endOffsets": "208,312,420,506,611,730,813,895,992,1091,1188,1288,1395,1494,1595,1691,1788,1879,1966,2072,2179,2280,2387,2498,2602,2758,2856,2940"
+ }
+ }
+ ]
+ }
+ ]
+}
\ No newline at end of file
diff --git a/src/src/app/build/intermediates/blame/res/debug/multi-v2/values-ml.json b/src/src/app/build/intermediates/blame/res/debug/multi-v2/values-ml.json
new file mode 100644
index 0000000..7274758
--- /dev/null
+++ b/src/src/app/build/intermediates/blame/res/debug/multi-v2/values-ml.json
@@ -0,0 +1,36 @@
+{
+ "logs": [
+ {
+ "outputFile": "E:\\Note\\src\\app\\build\\intermediates\\incremental\\mergeDebugResources\\merged.dir\\values-ml\\values-ml.xml",
+ "map": [
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\6d11613c3b6a00a9ea456b5609ec43f7\\core-1.0.0\\res\\values-ml\\values-ml.xml",
+ "from": {
+ "startLines": "2",
+ "startColumns": "4",
+ "startOffsets": "55",
+ "endColumns": "100",
+ "endOffsets": "151"
+ },
+ "to": {
+ "startLines": "30",
+ "startColumns": "4",
+ "startOffsets": "2955",
+ "endColumns": "100",
+ "endOffsets": "3051"
+ }
+ },
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\88c548461109b0c917067cfea58751b3\\appcompat-1.0.0-alpha1\\res\\values-ml\\values-ml.xml",
+ "from": {
+ "startLines": "2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19,20,21,22,23,24,25,26,27,28,29",
+ "startColumns": "4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4",
+ "startOffsets": "105,224,342,457,550,655,787,864,940,1031,1124,1226,1320,1421,1515,1610,1709,1800,1891,1973,2084,2190,2288,2402,2502,2613,2772,2873",
+ "endColumns": "118,117,114,92,104,131,76,75,90,92,101,93,100,93,94,98,90,90,81,110,105,97,113,99,110,158,100,81",
+ "endOffsets": "219,337,452,545,650,782,859,935,1026,1119,1221,1315,1416,1510,1605,1704,1795,1886,1968,2079,2185,2283,2397,2497,2608,2767,2868,2950"
+ }
+ }
+ ]
+ }
+ ]
+}
\ No newline at end of file
diff --git a/src/src/app/build/intermediates/blame/res/debug/multi-v2/values-mn.json b/src/src/app/build/intermediates/blame/res/debug/multi-v2/values-mn.json
new file mode 100644
index 0000000..81d2ef8
--- /dev/null
+++ b/src/src/app/build/intermediates/blame/res/debug/multi-v2/values-mn.json
@@ -0,0 +1,36 @@
+{
+ "logs": [
+ {
+ "outputFile": "E:\\Note\\src\\app\\build\\intermediates\\incremental\\mergeDebugResources\\merged.dir\\values-mn\\values-mn.xml",
+ "map": [
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\6d11613c3b6a00a9ea456b5609ec43f7\\core-1.0.0\\res\\values-mn\\values-mn.xml",
+ "from": {
+ "startLines": "2",
+ "startColumns": "4",
+ "startOffsets": "55",
+ "endColumns": "100",
+ "endOffsets": "151"
+ },
+ "to": {
+ "startLines": "30",
+ "startColumns": "4",
+ "startOffsets": "2876",
+ "endColumns": "100",
+ "endOffsets": "2972"
+ }
+ },
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\88c548461109b0c917067cfea58751b3\\appcompat-1.0.0-alpha1\\res\\values-mn\\values-mn.xml",
+ "from": {
+ "startLines": "2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19,20,21,22,23,24,25,26,27,28,29",
+ "startColumns": "4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4",
+ "startOffsets": "105,218,318,431,518,624,736,818,900,991,1084,1180,1276,1374,1467,1562,1654,1745,1835,1917,2026,2130,2227,2335,2436,2539,2698,2795",
+ "endColumns": "112,99,112,86,105,111,81,81,90,92,95,95,97,92,94,91,90,89,81,108,103,96,107,100,102,158,96,80",
+ "endOffsets": "213,313,426,513,619,731,813,895,986,1079,1175,1271,1369,1462,1557,1649,1740,1830,1912,2021,2125,2222,2330,2431,2534,2693,2790,2871"
+ }
+ }
+ ]
+ }
+ ]
+}
\ No newline at end of file
diff --git a/src/src/app/build/intermediates/blame/res/debug/multi-v2/values-mr.json b/src/src/app/build/intermediates/blame/res/debug/multi-v2/values-mr.json
new file mode 100644
index 0000000..f83f164
--- /dev/null
+++ b/src/src/app/build/intermediates/blame/res/debug/multi-v2/values-mr.json
@@ -0,0 +1,36 @@
+{
+ "logs": [
+ {
+ "outputFile": "E:\\Note\\src\\app\\build\\intermediates\\incremental\\mergeDebugResources\\merged.dir\\values-mr\\values-mr.xml",
+ "map": [
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\88c548461109b0c917067cfea58751b3\\appcompat-1.0.0-alpha1\\res\\values-mr\\values-mr.xml",
+ "from": {
+ "startLines": "2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19,20,21,22,23,24,25,26,27,28,29",
+ "startColumns": "4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4",
+ "startOffsets": "105,216,322,429,519,620,735,812,890,981,1074,1168,1265,1366,1459,1554,1651,1742,1833,1913,2025,2127,2223,2332,2433,2545,2702,2807",
+ "endColumns": "110,105,106,89,100,114,76,77,90,92,93,96,100,92,94,96,90,90,79,111,101,95,108,100,111,156,104,79",
+ "endOffsets": "211,317,424,514,615,730,807,885,976,1069,1163,1260,1361,1454,1549,1646,1737,1828,1908,2020,2122,2218,2327,2428,2540,2697,2802,2882"
+ }
+ },
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\6d11613c3b6a00a9ea456b5609ec43f7\\core-1.0.0\\res\\values-mr\\values-mr.xml",
+ "from": {
+ "startLines": "2",
+ "startColumns": "4",
+ "startOffsets": "55",
+ "endColumns": "100",
+ "endOffsets": "151"
+ },
+ "to": {
+ "startLines": "30",
+ "startColumns": "4",
+ "startOffsets": "2887",
+ "endColumns": "100",
+ "endOffsets": "2983"
+ }
+ }
+ ]
+ }
+ ]
+}
\ No newline at end of file
diff --git a/src/src/app/build/intermediates/blame/res/debug/multi-v2/values-ms.json b/src/src/app/build/intermediates/blame/res/debug/multi-v2/values-ms.json
new file mode 100644
index 0000000..ab88419
--- /dev/null
+++ b/src/src/app/build/intermediates/blame/res/debug/multi-v2/values-ms.json
@@ -0,0 +1,36 @@
+{
+ "logs": [
+ {
+ "outputFile": "E:\\Note\\src\\app\\build\\intermediates\\incremental\\mergeDebugResources\\merged.dir\\values-ms\\values-ms.xml",
+ "map": [
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\6d11613c3b6a00a9ea456b5609ec43f7\\core-1.0.0\\res\\values-ms\\values-ms.xml",
+ "from": {
+ "startLines": "2",
+ "startColumns": "4",
+ "startOffsets": "55",
+ "endColumns": "100",
+ "endOffsets": "151"
+ },
+ "to": {
+ "startLines": "30",
+ "startColumns": "4",
+ "startOffsets": "2881",
+ "endColumns": "100",
+ "endOffsets": "2977"
+ }
+ },
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\88c548461109b0c917067cfea58751b3\\appcompat-1.0.0-alpha1\\res\\values-ms\\values-ms.xml",
+ "from": {
+ "startLines": "2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19,20,21,22,23,24,25,26,27,28,29",
+ "startColumns": "4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4",
+ "startOffsets": "105,216,321,429,516,620,731,809,888,979,1072,1167,1261,1360,1453,1548,1642,1733,1824,1904,2016,2125,2222,2331,2434,2541,2700,2801",
+ "endColumns": "110,104,107,86,103,110,77,78,90,92,94,93,98,92,94,93,90,90,79,111,108,96,108,102,106,158,100,79",
+ "endOffsets": "211,316,424,511,615,726,804,883,974,1067,1162,1256,1355,1448,1543,1637,1728,1819,1899,2011,2120,2217,2326,2429,2536,2695,2796,2876"
+ }
+ }
+ ]
+ }
+ ]
+}
\ No newline at end of file
diff --git a/src/src/app/build/intermediates/blame/res/debug/multi-v2/values-my.json b/src/src/app/build/intermediates/blame/res/debug/multi-v2/values-my.json
new file mode 100644
index 0000000..33e5beb
--- /dev/null
+++ b/src/src/app/build/intermediates/blame/res/debug/multi-v2/values-my.json
@@ -0,0 +1,36 @@
+{
+ "logs": [
+ {
+ "outputFile": "E:\\Note\\src\\app\\build\\intermediates\\incremental\\mergeDebugResources\\merged.dir\\values-my\\values-my.xml",
+ "map": [
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\88c548461109b0c917067cfea58751b3\\appcompat-1.0.0-alpha1\\res\\values-my\\values-my.xml",
+ "from": {
+ "startLines": "2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19,20,21,22,23,24,25,26,27,28,29",
+ "startColumns": "4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4",
+ "startOffsets": "105,214,319,436,529,641,769,847,926,1017,1110,1206,1300,1401,1494,1589,1683,1774,1865,1951,2074,2186,2288,2414,2525,2635,2795,2895",
+ "endColumns": "108,104,116,92,111,127,77,78,90,92,95,93,100,92,94,93,90,90,85,122,111,101,125,110,109,159,99,83",
+ "endOffsets": "209,314,431,524,636,764,842,921,1012,1105,1201,1295,1396,1489,1584,1678,1769,1860,1946,2069,2181,2283,2409,2520,2630,2790,2890,2974"
+ }
+ },
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\6d11613c3b6a00a9ea456b5609ec43f7\\core-1.0.0\\res\\values-my\\values-my.xml",
+ "from": {
+ "startLines": "2",
+ "startColumns": "4",
+ "startOffsets": "55",
+ "endColumns": "100",
+ "endOffsets": "151"
+ },
+ "to": {
+ "startLines": "30",
+ "startColumns": "4",
+ "startOffsets": "2979",
+ "endColumns": "100",
+ "endOffsets": "3075"
+ }
+ }
+ ]
+ }
+ ]
+}
\ No newline at end of file
diff --git a/src/src/app/build/intermediates/blame/res/debug/multi-v2/values-nb.json b/src/src/app/build/intermediates/blame/res/debug/multi-v2/values-nb.json
new file mode 100644
index 0000000..6121414
--- /dev/null
+++ b/src/src/app/build/intermediates/blame/res/debug/multi-v2/values-nb.json
@@ -0,0 +1,36 @@
+{
+ "logs": [
+ {
+ "outputFile": "E:\\Note\\src\\app\\build\\intermediates\\incremental\\mergeDebugResources\\merged.dir\\values-nb\\values-nb.xml",
+ "map": [
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\88c548461109b0c917067cfea58751b3\\appcompat-1.0.0-alpha1\\res\\values-nb\\values-nb.xml",
+ "from": {
+ "startLines": "2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19,20,21,22,23,24,25,26,27,28,29",
+ "startColumns": "4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4",
+ "startOffsets": "105,213,308,422,508,608,721,797,873,964,1057,1153,1247,1348,1441,1536,1634,1725,1816,1896,1999,2098,2194,2298,2396,2497,2650,2747",
+ "endColumns": "107,94,113,85,99,112,75,75,90,92,95,93,100,92,94,97,90,90,79,102,98,95,103,97,100,152,96,78",
+ "endOffsets": "208,303,417,503,603,716,792,868,959,1052,1148,1242,1343,1436,1531,1629,1720,1811,1891,1994,2093,2189,2293,2391,2492,2645,2742,2821"
+ }
+ },
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\6d11613c3b6a00a9ea456b5609ec43f7\\core-1.0.0\\res\\values-nb\\values-nb.xml",
+ "from": {
+ "startLines": "2",
+ "startColumns": "4",
+ "startOffsets": "55",
+ "endColumns": "100",
+ "endOffsets": "151"
+ },
+ "to": {
+ "startLines": "30",
+ "startColumns": "4",
+ "startOffsets": "2826",
+ "endColumns": "100",
+ "endOffsets": "2922"
+ }
+ }
+ ]
+ }
+ ]
+}
\ No newline at end of file
diff --git a/src/src/app/build/intermediates/blame/res/debug/multi-v2/values-ne.json b/src/src/app/build/intermediates/blame/res/debug/multi-v2/values-ne.json
new file mode 100644
index 0000000..3b1fb19
--- /dev/null
+++ b/src/src/app/build/intermediates/blame/res/debug/multi-v2/values-ne.json
@@ -0,0 +1,36 @@
+{
+ "logs": [
+ {
+ "outputFile": "E:\\Note\\src\\app\\build\\intermediates\\incremental\\mergeDebugResources\\merged.dir\\values-ne\\values-ne.xml",
+ "map": [
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\88c548461109b0c917067cfea58751b3\\appcompat-1.0.0-alpha1\\res\\values-ne\\values-ne.xml",
+ "from": {
+ "startLines": "2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19,20,21,22,23,24,25,26,27,28,29",
+ "startColumns": "4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4",
+ "startOffsets": "105,210,314,422,513,620,747,841,931,1022,1115,1211,1305,1406,1499,1594,1688,1779,1870,1958,2068,2184,2287,2402,2504,2619,2790,2902",
+ "endColumns": "104,103,107,90,106,126,93,89,90,92,95,93,100,92,94,93,90,90,87,109,115,102,114,101,114,170,111,85",
+ "endOffsets": "205,309,417,508,615,742,836,926,1017,1110,1206,1300,1401,1494,1589,1683,1774,1865,1953,2063,2179,2282,2397,2499,2614,2785,2897,2983"
+ }
+ },
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\6d11613c3b6a00a9ea456b5609ec43f7\\core-1.0.0\\res\\values-ne\\values-ne.xml",
+ "from": {
+ "startLines": "2",
+ "startColumns": "4",
+ "startOffsets": "55",
+ "endColumns": "100",
+ "endOffsets": "151"
+ },
+ "to": {
+ "startLines": "30",
+ "startColumns": "4",
+ "startOffsets": "2988",
+ "endColumns": "100",
+ "endOffsets": "3084"
+ }
+ }
+ ]
+ }
+ ]
+}
\ No newline at end of file
diff --git a/src/src/app/build/intermediates/blame/res/debug/multi-v2/values-night-v8.json b/src/src/app/build/intermediates/blame/res/debug/multi-v2/values-night-v8.json
new file mode 100644
index 0000000..a301606
--- /dev/null
+++ b/src/src/app/build/intermediates/blame/res/debug/multi-v2/values-night-v8.json
@@ -0,0 +1,19 @@
+{
+ "logs": [
+ {
+ "outputFile": "E:\\Note\\src\\app\\build\\intermediates\\incremental\\mergeDebugResources\\merged.dir\\values-night-v8\\values-night-v8.xml",
+ "map": [
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\88c548461109b0c917067cfea58751b3\\appcompat-1.0.0-alpha1\\res\\values-night-v8\\values-night-v8.xml",
+ "from": {
+ "startLines": "2,3,4,5,6,7,8",
+ "startColumns": "4,4,4,4,4,4,4",
+ "startOffsets": "55,125,209,293,389,491,593",
+ "endColumns": "69,83,83,95,101,101,93",
+ "endOffsets": "120,204,288,384,486,588,682"
+ }
+ }
+ ]
+ }
+ ]
+}
\ No newline at end of file
diff --git a/src/src/app/build/intermediates/blame/res/debug/multi-v2/values-nl.json b/src/src/app/build/intermediates/blame/res/debug/multi-v2/values-nl.json
new file mode 100644
index 0000000..5936733
--- /dev/null
+++ b/src/src/app/build/intermediates/blame/res/debug/multi-v2/values-nl.json
@@ -0,0 +1,36 @@
+{
+ "logs": [
+ {
+ "outputFile": "E:\\Note\\src\\app\\build\\intermediates\\incremental\\mergeDebugResources\\merged.dir\\values-nl\\values-nl.xml",
+ "map": [
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\88c548461109b0c917067cfea58751b3\\appcompat-1.0.0-alpha1\\res\\values-nl\\values-nl.xml",
+ "from": {
+ "startLines": "2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19,20,21,22,23,24,25,26,27,28,29",
+ "startColumns": "4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4",
+ "startOffsets": "105,223,328,435,521,629,749,826,903,995,1089,1190,1284,1385,1479,1575,1670,1762,1854,1936,2047,2151,2250,2365,2478,2581,2736,2839",
+ "endColumns": "117,104,106,85,107,119,76,76,91,93,100,93,100,93,95,94,91,91,81,110,103,98,114,112,102,154,102,81",
+ "endOffsets": "218,323,430,516,624,744,821,898,990,1084,1185,1279,1380,1474,1570,1665,1757,1849,1931,2042,2146,2245,2360,2473,2576,2731,2834,2916"
+ }
+ },
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\6d11613c3b6a00a9ea456b5609ec43f7\\core-1.0.0\\res\\values-nl\\values-nl.xml",
+ "from": {
+ "startLines": "2",
+ "startColumns": "4",
+ "startOffsets": "55",
+ "endColumns": "100",
+ "endOffsets": "151"
+ },
+ "to": {
+ "startLines": "30",
+ "startColumns": "4",
+ "startOffsets": "2921",
+ "endColumns": "100",
+ "endOffsets": "3017"
+ }
+ }
+ ]
+ }
+ ]
+}
\ No newline at end of file
diff --git a/src/src/app/build/intermediates/blame/res/debug/multi-v2/values-or.json b/src/src/app/build/intermediates/blame/res/debug/multi-v2/values-or.json
new file mode 100644
index 0000000..fd33907
--- /dev/null
+++ b/src/src/app/build/intermediates/blame/res/debug/multi-v2/values-or.json
@@ -0,0 +1,36 @@
+{
+ "logs": [
+ {
+ "outputFile": "E:\\Note\\src\\app\\build\\intermediates\\incremental\\mergeDebugResources\\merged.dir\\values-or\\values-or.xml",
+ "map": [
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\88c548461109b0c917067cfea58751b3\\appcompat-1.0.0-alpha1\\res\\values-or\\values-or.xml",
+ "from": {
+ "startLines": "2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19,20,21,22,23,24,25,26,27,28,29",
+ "startColumns": "4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4",
+ "startOffsets": "105,224,334,441,527,631,751,828,905,996,1089,1186,1281,1382,1475,1570,1666,1757,1847,1929,2039,2144,2250,2361,2464,2582,2745,2847",
+ "endColumns": "118,109,106,85,103,119,76,76,90,92,96,94,100,92,94,95,90,89,81,109,104,105,110,102,117,162,101,88",
+ "endOffsets": "219,329,436,522,626,746,823,900,991,1084,1181,1276,1377,1470,1565,1661,1752,1842,1924,2034,2139,2245,2356,2459,2577,2740,2842,2931"
+ }
+ },
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\6d11613c3b6a00a9ea456b5609ec43f7\\core-1.0.0\\res\\values-or\\values-or.xml",
+ "from": {
+ "startLines": "2",
+ "startColumns": "4",
+ "startOffsets": "55",
+ "endColumns": "100",
+ "endOffsets": "151"
+ },
+ "to": {
+ "startLines": "30",
+ "startColumns": "4",
+ "startOffsets": "2936",
+ "endColumns": "100",
+ "endOffsets": "3032"
+ }
+ }
+ ]
+ }
+ ]
+}
\ No newline at end of file
diff --git a/src/src/app/build/intermediates/blame/res/debug/multi-v2/values-pa.json b/src/src/app/build/intermediates/blame/res/debug/multi-v2/values-pa.json
new file mode 100644
index 0000000..8f4fc42
--- /dev/null
+++ b/src/src/app/build/intermediates/blame/res/debug/multi-v2/values-pa.json
@@ -0,0 +1,36 @@
+{
+ "logs": [
+ {
+ "outputFile": "E:\\Note\\src\\app\\build\\intermediates\\incremental\\mergeDebugResources\\merged.dir\\values-pa\\values-pa.xml",
+ "map": [
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\6d11613c3b6a00a9ea456b5609ec43f7\\core-1.0.0\\res\\values-pa\\values-pa.xml",
+ "from": {
+ "startLines": "2",
+ "startColumns": "4",
+ "startOffsets": "55",
+ "endColumns": "100",
+ "endOffsets": "151"
+ },
+ "to": {
+ "startLines": "30",
+ "startColumns": "4",
+ "startOffsets": "2839",
+ "endColumns": "100",
+ "endOffsets": "2935"
+ }
+ },
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\88c548461109b0c917067cfea58751b3\\appcompat-1.0.0-alpha1\\res\\values-pa\\values-pa.xml",
+ "from": {
+ "startLines": "2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19,20,21,22,23,24,25,26,27,28,29",
+ "startColumns": "4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4",
+ "startOffsets": "105,208,305,410,496,596,709,786,862,953,1046,1142,1236,1337,1430,1525,1619,1710,1801,1880,1981,2085,2182,2291,2390,2500,2659,2759",
+ "endColumns": "102,96,104,85,99,112,76,75,90,92,95,93,100,92,94,93,90,90,78,100,103,96,108,98,109,158,99,79",
+ "endOffsets": "203,300,405,491,591,704,781,857,948,1041,1137,1231,1332,1425,1520,1614,1705,1796,1875,1976,2080,2177,2286,2385,2495,2654,2754,2834"
+ }
+ }
+ ]
+ }
+ ]
+}
\ No newline at end of file
diff --git a/src/src/app/build/intermediates/blame/res/debug/multi-v2/values-pl.json b/src/src/app/build/intermediates/blame/res/debug/multi-v2/values-pl.json
new file mode 100644
index 0000000..7f8cdc7
--- /dev/null
+++ b/src/src/app/build/intermediates/blame/res/debug/multi-v2/values-pl.json
@@ -0,0 +1,36 @@
+{
+ "logs": [
+ {
+ "outputFile": "E:\\Note\\src\\app\\build\\intermediates\\incremental\\mergeDebugResources\\merged.dir\\values-pl\\values-pl.xml",
+ "map": [
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\6d11613c3b6a00a9ea456b5609ec43f7\\core-1.0.0\\res\\values-pl\\values-pl.xml",
+ "from": {
+ "startLines": "2",
+ "startColumns": "4",
+ "startOffsets": "55",
+ "endColumns": "100",
+ "endOffsets": "151"
+ },
+ "to": {
+ "startLines": "30",
+ "startColumns": "4",
+ "startOffsets": "2909",
+ "endColumns": "100",
+ "endOffsets": "3005"
+ }
+ },
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\88c548461109b0c917067cfea58751b3\\appcompat-1.0.0-alpha1\\res\\values-pl\\values-pl.xml",
+ "from": {
+ "startLines": "2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19,20,21,22,23,24,25,26,27,28,29",
+ "startColumns": "4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4",
+ "startOffsets": "105,221,323,431,517,626,745,823,900,991,1084,1180,1274,1376,1469,1564,1659,1750,1841,1923,2032,2141,2240,2349,2460,2568,2731,2827",
+ "endColumns": "115,101,107,85,108,118,77,76,90,92,95,93,101,92,94,94,90,90,81,108,108,98,108,110,107,162,95,81",
+ "endOffsets": "216,318,426,512,621,740,818,895,986,1079,1175,1269,1371,1464,1559,1654,1745,1836,1918,2027,2136,2235,2344,2455,2563,2726,2822,2904"
+ }
+ }
+ ]
+ }
+ ]
+}
\ No newline at end of file
diff --git a/src/src/app/build/intermediates/blame/res/debug/multi-v2/values-port.json b/src/src/app/build/intermediates/blame/res/debug/multi-v2/values-port.json
new file mode 100644
index 0000000..ac0b9dc
--- /dev/null
+++ b/src/src/app/build/intermediates/blame/res/debug/multi-v2/values-port.json
@@ -0,0 +1,19 @@
+{
+ "logs": [
+ {
+ "outputFile": "E:\\Note\\src\\app\\build\\intermediates\\incremental\\mergeDebugResources\\merged.dir\\values-port\\values-port.xml",
+ "map": [
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\88c548461109b0c917067cfea58751b3\\appcompat-1.0.0-alpha1\\res\\values-port\\values-port.xml",
+ "from": {
+ "startLines": "2",
+ "startColumns": "4",
+ "startOffsets": "55",
+ "endColumns": "55",
+ "endOffsets": "106"
+ }
+ }
+ ]
+ }
+ ]
+}
\ No newline at end of file
diff --git a/src/src/app/build/intermediates/blame/res/debug/multi-v2/values-pt-rBR.json b/src/src/app/build/intermediates/blame/res/debug/multi-v2/values-pt-rBR.json
new file mode 100644
index 0000000..1f4b21e
--- /dev/null
+++ b/src/src/app/build/intermediates/blame/res/debug/multi-v2/values-pt-rBR.json
@@ -0,0 +1,36 @@
+{
+ "logs": [
+ {
+ "outputFile": "E:\\Note\\src\\app\\build\\intermediates\\incremental\\mergeDebugResources\\merged.dir\\values-pt-rBR\\values-pt-rBR.xml",
+ "map": [
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\88c548461109b0c917067cfea58751b3\\appcompat-1.0.0-alpha1\\res\\values-pt-rBR\\values-pt-rBR.xml",
+ "from": {
+ "startLines": "2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19,20,21,22,23,24,25,26,27,28,29",
+ "startColumns": "4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4",
+ "startOffsets": "105,225,331,438,527,628,746,829,909,1000,1093,1189,1283,1384,1477,1572,1667,1758,1849,1936,2043,2155,2257,2365,2472,2582,2744,2844",
+ "endColumns": "119,105,106,88,100,117,82,79,90,92,95,93,100,92,94,94,90,90,86,106,111,101,107,106,109,161,99,84",
+ "endOffsets": "220,326,433,522,623,741,824,904,995,1088,1184,1278,1379,1472,1567,1662,1753,1844,1931,2038,2150,2252,2360,2467,2577,2739,2839,2924"
+ }
+ },
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\6d11613c3b6a00a9ea456b5609ec43f7\\core-1.0.0\\res\\values-pt-rBR\\values-pt-rBR.xml",
+ "from": {
+ "startLines": "2",
+ "startColumns": "4",
+ "startOffsets": "55",
+ "endColumns": "100",
+ "endOffsets": "151"
+ },
+ "to": {
+ "startLines": "30",
+ "startColumns": "4",
+ "startOffsets": "2929",
+ "endColumns": "100",
+ "endOffsets": "3025"
+ }
+ }
+ ]
+ }
+ ]
+}
\ No newline at end of file
diff --git a/src/src/app/build/intermediates/blame/res/debug/multi-v2/values-pt-rPT.json b/src/src/app/build/intermediates/blame/res/debug/multi-v2/values-pt-rPT.json
new file mode 100644
index 0000000..0e0f14d
--- /dev/null
+++ b/src/src/app/build/intermediates/blame/res/debug/multi-v2/values-pt-rPT.json
@@ -0,0 +1,36 @@
+{
+ "logs": [
+ {
+ "outputFile": "E:\\Note\\src\\app\\build\\intermediates\\incremental\\mergeDebugResources\\merged.dir\\values-pt-rPT\\values-pt-rPT.xml",
+ "map": [
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\6d11613c3b6a00a9ea456b5609ec43f7\\core-1.0.0\\res\\values-pt-rPT\\values-pt-rPT.xml",
+ "from": {
+ "startLines": "2",
+ "startColumns": "4",
+ "startOffsets": "55",
+ "endColumns": "100",
+ "endOffsets": "151"
+ },
+ "to": {
+ "startLines": "30",
+ "startColumns": "4",
+ "startOffsets": "2949",
+ "endColumns": "100",
+ "endOffsets": "3045"
+ }
+ },
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\88c548461109b0c917067cfea58751b3\\appcompat-1.0.0-alpha1\\res\\values-pt-rPT\\values-pt-rPT.xml",
+ "from": {
+ "startLines": "2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19,20,21,22,23,24,25,26,27,28,29",
+ "startColumns": "4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4",
+ "startOffsets": "105,225,331,438,527,628,752,836,917,1009,1103,1201,1295,1395,1489,1585,1680,1772,1864,1951,2058,2170,2272,2380,2487,2594,2765,2864",
+ "endColumns": "119,105,106,88,100,123,83,80,91,93,97,93,99,93,95,94,91,91,86,106,111,101,107,106,106,170,98,84",
+ "endOffsets": "220,326,433,522,623,747,831,912,1004,1098,1196,1290,1390,1484,1580,1675,1767,1859,1946,2053,2165,2267,2375,2482,2589,2760,2859,2944"
+ }
+ }
+ ]
+ }
+ ]
+}
\ No newline at end of file
diff --git a/src/src/app/build/intermediates/blame/res/debug/multi-v2/values-pt.json b/src/src/app/build/intermediates/blame/res/debug/multi-v2/values-pt.json
new file mode 100644
index 0000000..04cfb27
--- /dev/null
+++ b/src/src/app/build/intermediates/blame/res/debug/multi-v2/values-pt.json
@@ -0,0 +1,36 @@
+{
+ "logs": [
+ {
+ "outputFile": "E:\\Note\\src\\app\\build\\intermediates\\incremental\\mergeDebugResources\\merged.dir\\values-pt\\values-pt.xml",
+ "map": [
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\88c548461109b0c917067cfea58751b3\\appcompat-1.0.0-alpha1\\res\\values-pt\\values-pt.xml",
+ "from": {
+ "startLines": "2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19,20,21,22,23,24,25,26,27,28,29",
+ "startColumns": "4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4",
+ "startOffsets": "105,225,331,438,527,628,746,829,909,1000,1093,1189,1283,1384,1477,1572,1667,1758,1849,1936,2043,2155,2257,2365,2472,2582,2744,2844",
+ "endColumns": "119,105,106,88,100,117,82,79,90,92,95,93,100,92,94,94,90,90,86,106,111,101,107,106,109,161,99,84",
+ "endOffsets": "220,326,433,522,623,741,824,904,995,1088,1184,1278,1379,1472,1567,1662,1753,1844,1931,2038,2150,2252,2360,2467,2577,2739,2839,2924"
+ }
+ },
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\6d11613c3b6a00a9ea456b5609ec43f7\\core-1.0.0\\res\\values-pt\\values-pt.xml",
+ "from": {
+ "startLines": "2",
+ "startColumns": "4",
+ "startOffsets": "55",
+ "endColumns": "100",
+ "endOffsets": "151"
+ },
+ "to": {
+ "startLines": "30",
+ "startColumns": "4",
+ "startOffsets": "2929",
+ "endColumns": "100",
+ "endOffsets": "3025"
+ }
+ }
+ ]
+ }
+ ]
+}
\ No newline at end of file
diff --git a/src/src/app/build/intermediates/blame/res/debug/multi-v2/values-ro.json b/src/src/app/build/intermediates/blame/res/debug/multi-v2/values-ro.json
new file mode 100644
index 0000000..51e856f
--- /dev/null
+++ b/src/src/app/build/intermediates/blame/res/debug/multi-v2/values-ro.json
@@ -0,0 +1,36 @@
+{
+ "logs": [
+ {
+ "outputFile": "E:\\Note\\src\\app\\build\\intermediates\\incremental\\mergeDebugResources\\merged.dir\\values-ro\\values-ro.xml",
+ "map": [
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\6d11613c3b6a00a9ea456b5609ec43f7\\core-1.0.0\\res\\values-ro\\values-ro.xml",
+ "from": {
+ "startLines": "2",
+ "startColumns": "4",
+ "startOffsets": "55",
+ "endColumns": "100",
+ "endOffsets": "151"
+ },
+ "to": {
+ "startLines": "30",
+ "startColumns": "4",
+ "startOffsets": "2953",
+ "endColumns": "100",
+ "endOffsets": "3049"
+ }
+ },
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\88c548461109b0c917067cfea58751b3\\appcompat-1.0.0-alpha1\\res\\values-ro\\values-ro.xml",
+ "from": {
+ "startLines": "2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19,20,21,22,23,24,25,26,27,28,29",
+ "startColumns": "4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4",
+ "startOffsets": "105,226,330,443,531,643,764,849,930,1021,1114,1210,1304,1404,1497,1592,1687,1778,1870,1953,2065,2178,2278,2392,2497,2603,2767,2870",
+ "endColumns": "120,103,112,87,111,120,84,80,90,92,95,93,99,92,94,94,90,91,82,111,112,99,113,104,105,163,102,82",
+ "endOffsets": "221,325,438,526,638,759,844,925,1016,1109,1205,1299,1399,1492,1587,1682,1773,1865,1948,2060,2173,2273,2387,2492,2598,2762,2865,2948"
+ }
+ }
+ ]
+ }
+ ]
+}
\ No newline at end of file
diff --git a/src/src/app/build/intermediates/blame/res/debug/multi-v2/values-ru.json b/src/src/app/build/intermediates/blame/res/debug/multi-v2/values-ru.json
new file mode 100644
index 0000000..a1676ee
--- /dev/null
+++ b/src/src/app/build/intermediates/blame/res/debug/multi-v2/values-ru.json
@@ -0,0 +1,36 @@
+{
+ "logs": [
+ {
+ "outputFile": "E:\\Note\\src\\app\\build\\intermediates\\incremental\\mergeDebugResources\\merged.dir\\values-ru\\values-ru.xml",
+ "map": [
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\88c548461109b0c917067cfea58751b3\\appcompat-1.0.0-alpha1\\res\\values-ru\\values-ru.xml",
+ "from": {
+ "startLines": "2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19,20,21,22,23,24,25,26,27,28,29",
+ "startColumns": "4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4",
+ "startOffsets": "105,220,322,434,520,625,745,824,902,994,1088,1184,1277,1373,1467,1563,1658,1750,1842,1922,2028,2136,2234,2343,2449,2557,2732,2832",
+ "endColumns": "114,101,111,85,104,119,78,77,91,93,95,92,95,93,95,94,91,91,79,105,107,97,108,105,107,174,99,80",
+ "endOffsets": "215,317,429,515,620,740,819,897,989,1083,1179,1272,1368,1462,1558,1653,1745,1837,1917,2023,2131,2229,2338,2444,2552,2727,2827,2908"
+ }
+ },
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\6d11613c3b6a00a9ea456b5609ec43f7\\core-1.0.0\\res\\values-ru\\values-ru.xml",
+ "from": {
+ "startLines": "2",
+ "startColumns": "4",
+ "startOffsets": "55",
+ "endColumns": "100",
+ "endOffsets": "151"
+ },
+ "to": {
+ "startLines": "30",
+ "startColumns": "4",
+ "startOffsets": "2913",
+ "endColumns": "100",
+ "endOffsets": "3009"
+ }
+ }
+ ]
+ }
+ ]
+}
\ No newline at end of file
diff --git a/src/src/app/build/intermediates/blame/res/debug/multi-v2/values-si.json b/src/src/app/build/intermediates/blame/res/debug/multi-v2/values-si.json
new file mode 100644
index 0000000..1ba55cb
--- /dev/null
+++ b/src/src/app/build/intermediates/blame/res/debug/multi-v2/values-si.json
@@ -0,0 +1,36 @@
+{
+ "logs": [
+ {
+ "outputFile": "E:\\Note\\src\\app\\build\\intermediates\\incremental\\mergeDebugResources\\merged.dir\\values-si\\values-si.xml",
+ "map": [
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\6d11613c3b6a00a9ea456b5609ec43f7\\core-1.0.0\\res\\values-si\\values-si.xml",
+ "from": {
+ "startLines": "2",
+ "startColumns": "4",
+ "startOffsets": "55",
+ "endColumns": "100",
+ "endOffsets": "151"
+ },
+ "to": {
+ "startLines": "30",
+ "startColumns": "4",
+ "startOffsets": "2903",
+ "endColumns": "100",
+ "endOffsets": "2999"
+ }
+ },
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\88c548461109b0c917067cfea58751b3\\appcompat-1.0.0-alpha1\\res\\values-si\\values-si.xml",
+ "from": {
+ "startLines": "2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19,20,21,22,23,24,25,26,27,28,29",
+ "startColumns": "4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4",
+ "startOffsets": "105,215,322,429,517,622,738,827,914,1005,1098,1193,1287,1388,1481,1576,1670,1761,1852,1936,2045,2150,2248,2358,2457,2563,2722,2821",
+ "endColumns": "109,106,106,87,104,115,88,86,90,92,94,93,100,92,94,93,90,90,83,108,104,97,109,98,105,158,98,81",
+ "endOffsets": "210,317,424,512,617,733,822,909,1000,1093,1188,1282,1383,1476,1571,1665,1756,1847,1931,2040,2145,2243,2353,2452,2558,2717,2816,2898"
+ }
+ }
+ ]
+ }
+ ]
+}
\ No newline at end of file
diff --git a/src/src/app/build/intermediates/blame/res/debug/multi-v2/values-sk.json b/src/src/app/build/intermediates/blame/res/debug/multi-v2/values-sk.json
new file mode 100644
index 0000000..ef1489c
--- /dev/null
+++ b/src/src/app/build/intermediates/blame/res/debug/multi-v2/values-sk.json
@@ -0,0 +1,36 @@
+{
+ "logs": [
+ {
+ "outputFile": "E:\\Note\\src\\app\\build\\intermediates\\incremental\\mergeDebugResources\\merged.dir\\values-sk\\values-sk.xml",
+ "map": [
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\6d11613c3b6a00a9ea456b5609ec43f7\\core-1.0.0\\res\\values-sk\\values-sk.xml",
+ "from": {
+ "startLines": "2",
+ "startColumns": "4",
+ "startOffsets": "55",
+ "endColumns": "100",
+ "endOffsets": "151"
+ },
+ "to": {
+ "startLines": "30",
+ "startColumns": "4",
+ "startOffsets": "2918",
+ "endColumns": "100",
+ "endOffsets": "3014"
+ }
+ },
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\88c548461109b0c917067cfea58751b3\\appcompat-1.0.0-alpha1\\res\\values-sk\\values-sk.xml",
+ "from": {
+ "startLines": "2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19,20,21,22,23,24,25,26,27,28,29",
+ "startColumns": "4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4",
+ "startOffsets": "105,212,312,423,509,617,735,816,897,988,1081,1180,1274,1375,1468,1563,1661,1752,1843,1927,2032,2141,2240,2346,2457,2566,2732,2830",
+ "endColumns": "106,99,110,85,107,117,80,80,90,92,98,93,100,92,94,97,90,90,83,104,108,98,105,110,108,165,97,87",
+ "endOffsets": "207,307,418,504,612,730,811,892,983,1076,1175,1269,1370,1463,1558,1656,1747,1838,1922,2027,2136,2235,2341,2452,2561,2727,2825,2913"
+ }
+ }
+ ]
+ }
+ ]
+}
\ No newline at end of file
diff --git a/src/src/app/build/intermediates/blame/res/debug/multi-v2/values-sl.json b/src/src/app/build/intermediates/blame/res/debug/multi-v2/values-sl.json
new file mode 100644
index 0000000..ca7f8a1
--- /dev/null
+++ b/src/src/app/build/intermediates/blame/res/debug/multi-v2/values-sl.json
@@ -0,0 +1,36 @@
+{
+ "logs": [
+ {
+ "outputFile": "E:\\Note\\src\\app\\build\\intermediates\\incremental\\mergeDebugResources\\merged.dir\\values-sl\\values-sl.xml",
+ "map": [
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\88c548461109b0c917067cfea58751b3\\appcompat-1.0.0-alpha1\\res\\values-sl\\values-sl.xml",
+ "from": {
+ "startLines": "2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19,20,21,22,23,24,25,26,27,28,29",
+ "startColumns": "4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4",
+ "startOffsets": "105,212,319,427,514,617,736,821,905,997,1091,1187,1281,1377,1471,1567,1667,1759,1851,1935,2043,2152,2252,2365,2472,2576,2756,2853",
+ "endColumns": "106,106,107,86,102,118,84,83,91,93,95,93,95,93,95,99,91,91,83,107,108,99,112,106,103,179,96,82",
+ "endOffsets": "207,314,422,509,612,731,816,900,992,1086,1182,1276,1372,1466,1562,1662,1754,1846,1930,2038,2147,2247,2360,2467,2571,2751,2848,2931"
+ }
+ },
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\6d11613c3b6a00a9ea456b5609ec43f7\\core-1.0.0\\res\\values-sl\\values-sl.xml",
+ "from": {
+ "startLines": "2",
+ "startColumns": "4",
+ "startOffsets": "55",
+ "endColumns": "100",
+ "endOffsets": "151"
+ },
+ "to": {
+ "startLines": "30",
+ "startColumns": "4",
+ "startOffsets": "2936",
+ "endColumns": "100",
+ "endOffsets": "3032"
+ }
+ }
+ ]
+ }
+ ]
+}
\ No newline at end of file
diff --git a/src/src/app/build/intermediates/blame/res/debug/multi-v2/values-sq.json b/src/src/app/build/intermediates/blame/res/debug/multi-v2/values-sq.json
new file mode 100644
index 0000000..cd3cc36
--- /dev/null
+++ b/src/src/app/build/intermediates/blame/res/debug/multi-v2/values-sq.json
@@ -0,0 +1,36 @@
+{
+ "logs": [
+ {
+ "outputFile": "E:\\Note\\src\\app\\build\\intermediates\\incremental\\mergeDebugResources\\merged.dir\\values-sq\\values-sq.xml",
+ "map": [
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\88c548461109b0c917067cfea58751b3\\appcompat-1.0.0-alpha1\\res\\values-sq\\values-sq.xml",
+ "from": {
+ "startLines": "2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19,20,21,22,23,24,25,26,27,28,29",
+ "startColumns": "4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4",
+ "startOffsets": "105,219,319,431,518,628,751,832,911,1002,1095,1191,1285,1387,1480,1575,1672,1763,1856,1939,2045,2150,2248,2354,2457,2573,2727,2826",
+ "endColumns": "113,99,111,86,109,122,80,78,90,92,95,93,101,92,94,96,90,92,82,105,104,97,105,102,115,153,98,80",
+ "endOffsets": "214,314,426,513,623,746,827,906,997,1090,1186,1280,1382,1475,1570,1667,1758,1851,1934,2040,2145,2243,2349,2452,2568,2722,2821,2902"
+ }
+ },
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\6d11613c3b6a00a9ea456b5609ec43f7\\core-1.0.0\\res\\values-sq\\values-sq.xml",
+ "from": {
+ "startLines": "2",
+ "startColumns": "4",
+ "startOffsets": "55",
+ "endColumns": "100",
+ "endOffsets": "151"
+ },
+ "to": {
+ "startLines": "30",
+ "startColumns": "4",
+ "startOffsets": "2907",
+ "endColumns": "100",
+ "endOffsets": "3003"
+ }
+ }
+ ]
+ }
+ ]
+}
\ No newline at end of file
diff --git a/src/src/app/build/intermediates/blame/res/debug/multi-v2/values-sr.json b/src/src/app/build/intermediates/blame/res/debug/multi-v2/values-sr.json
new file mode 100644
index 0000000..c8ad618
--- /dev/null
+++ b/src/src/app/build/intermediates/blame/res/debug/multi-v2/values-sr.json
@@ -0,0 +1,36 @@
+{
+ "logs": [
+ {
+ "outputFile": "E:\\Note\\src\\app\\build\\intermediates\\incremental\\mergeDebugResources\\merged.dir\\values-sr\\values-sr.xml",
+ "map": [
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\6d11613c3b6a00a9ea456b5609ec43f7\\core-1.0.0\\res\\values-sr\\values-sr.xml",
+ "from": {
+ "startLines": "2",
+ "startColumns": "4",
+ "startOffsets": "55",
+ "endColumns": "100",
+ "endOffsets": "151"
+ },
+ "to": {
+ "startLines": "30",
+ "startColumns": "4",
+ "startOffsets": "2905",
+ "endColumns": "100",
+ "endOffsets": "3001"
+ }
+ },
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\88c548461109b0c917067cfea58751b3\\appcompat-1.0.0-alpha1\\res\\values-sr\\values-sr.xml",
+ "from": {
+ "startLines": "2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19,20,21,22,23,24,25,26,27,28,29",
+ "startColumns": "4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4",
+ "startOffsets": "105,214,317,423,509,613,731,812,892,983,1076,1172,1266,1367,1460,1555,1660,1751,1842,1930,2035,2143,2244,2348,2456,2557,2724,2821",
+ "endColumns": "108,102,105,85,103,117,80,79,90,92,95,93,100,92,94,104,90,90,87,104,107,100,103,107,100,166,96,83",
+ "endOffsets": "209,312,418,504,608,726,807,887,978,1071,1167,1261,1362,1455,1550,1655,1746,1837,1925,2030,2138,2239,2343,2451,2552,2719,2816,2900"
+ }
+ }
+ ]
+ }
+ ]
+}
\ No newline at end of file
diff --git a/src/src/app/build/intermediates/blame/res/debug/multi-v2/values-sv.json b/src/src/app/build/intermediates/blame/res/debug/multi-v2/values-sv.json
new file mode 100644
index 0000000..97d9fc0
--- /dev/null
+++ b/src/src/app/build/intermediates/blame/res/debug/multi-v2/values-sv.json
@@ -0,0 +1,36 @@
+{
+ "logs": [
+ {
+ "outputFile": "E:\\Note\\src\\app\\build\\intermediates\\incremental\\mergeDebugResources\\merged.dir\\values-sv\\values-sv.xml",
+ "map": [
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\6d11613c3b6a00a9ea456b5609ec43f7\\core-1.0.0\\res\\values-sv\\values-sv.xml",
+ "from": {
+ "startLines": "2",
+ "startColumns": "4",
+ "startOffsets": "55",
+ "endColumns": "100",
+ "endOffsets": "151"
+ },
+ "to": {
+ "startLines": "30",
+ "startColumns": "4",
+ "startOffsets": "2863",
+ "endColumns": "100",
+ "endOffsets": "2959"
+ }
+ },
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\88c548461109b0c917067cfea58751b3\\appcompat-1.0.0-alpha1\\res\\values-sv\\values-sv.xml",
+ "from": {
+ "startLines": "2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19,20,21,22,23,24,25,26,27,28,29",
+ "startColumns": "4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4",
+ "startOffsets": "105,211,314,425,510,612,725,801,877,970,1065,1161,1255,1358,1453,1550,1648,1744,1837,1917,2023,2123,2219,2324,2426,2528,2682,2784",
+ "endColumns": "105,102,110,84,101,112,75,75,92,94,95,93,102,94,96,97,95,92,79,105,99,95,104,101,101,153,101,78",
+ "endOffsets": "206,309,420,505,607,720,796,872,965,1060,1156,1250,1353,1448,1545,1643,1739,1832,1912,2018,2118,2214,2319,2421,2523,2677,2779,2858"
+ }
+ }
+ ]
+ }
+ ]
+}
\ No newline at end of file
diff --git a/src/src/app/build/intermediates/blame/res/debug/multi-v2/values-sw.json b/src/src/app/build/intermediates/blame/res/debug/multi-v2/values-sw.json
new file mode 100644
index 0000000..ab87cc6
--- /dev/null
+++ b/src/src/app/build/intermediates/blame/res/debug/multi-v2/values-sw.json
@@ -0,0 +1,36 @@
+{
+ "logs": [
+ {
+ "outputFile": "E:\\Note\\src\\app\\build\\intermediates\\incremental\\mergeDebugResources\\merged.dir\\values-sw\\values-sw.xml",
+ "map": [
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\88c548461109b0c917067cfea58751b3\\appcompat-1.0.0-alpha1\\res\\values-sw\\values-sw.xml",
+ "from": {
+ "startLines": "2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19,20,21,22,23,24,25,26,27,28,29",
+ "startColumns": "4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4",
+ "startOffsets": "105,208,306,414,504,609,726,808,891,982,1075,1169,1263,1364,1457,1552,1647,1738,1830,1912,2013,2122,2221,2328,2437,2542,2704,2801",
+ "endColumns": "102,97,107,89,104,116,81,82,90,92,93,93,100,92,94,94,90,91,81,100,108,98,106,108,104,161,96,81",
+ "endOffsets": "203,301,409,499,604,721,803,886,977,1070,1164,1258,1359,1452,1547,1642,1733,1825,1907,2008,2117,2216,2323,2432,2537,2699,2796,2878"
+ }
+ },
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\6d11613c3b6a00a9ea456b5609ec43f7\\core-1.0.0\\res\\values-sw\\values-sw.xml",
+ "from": {
+ "startLines": "2",
+ "startColumns": "4",
+ "startOffsets": "55",
+ "endColumns": "100",
+ "endOffsets": "151"
+ },
+ "to": {
+ "startLines": "30",
+ "startColumns": "4",
+ "startOffsets": "2883",
+ "endColumns": "100",
+ "endOffsets": "2979"
+ }
+ }
+ ]
+ }
+ ]
+}
\ No newline at end of file
diff --git a/src/src/app/build/intermediates/blame/res/debug/multi-v2/values-sw600dp-v13.json b/src/src/app/build/intermediates/blame/res/debug/multi-v2/values-sw600dp-v13.json
new file mode 100644
index 0000000..a6cd6e5
--- /dev/null
+++ b/src/src/app/build/intermediates/blame/res/debug/multi-v2/values-sw600dp-v13.json
@@ -0,0 +1,19 @@
+{
+ "logs": [
+ {
+ "outputFile": "E:\\Note\\src\\app\\build\\intermediates\\incremental\\mergeDebugResources\\merged.dir\\values-sw600dp-v13\\values-sw600dp-v13.xml",
+ "map": [
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\88c548461109b0c917067cfea58751b3\\appcompat-1.0.0-alpha1\\res\\values-sw600dp-v13\\values-sw600dp-v13.xml",
+ "from": {
+ "startLines": "2,3,4,5,6,7,8,9",
+ "startColumns": "4,4,4,4,4,4,4,4",
+ "startOffsets": "55,124,193,263,337,413,472,543",
+ "endColumns": "68,68,69,73,75,58,70,67",
+ "endOffsets": "119,188,258,332,408,467,538,606"
+ }
+ }
+ ]
+ }
+ ]
+}
\ No newline at end of file
diff --git a/src/src/app/build/intermediates/blame/res/debug/multi-v2/values-ta.json b/src/src/app/build/intermediates/blame/res/debug/multi-v2/values-ta.json
new file mode 100644
index 0000000..3966054
--- /dev/null
+++ b/src/src/app/build/intermediates/blame/res/debug/multi-v2/values-ta.json
@@ -0,0 +1,36 @@
+{
+ "logs": [
+ {
+ "outputFile": "E:\\Note\\src\\app\\build\\intermediates\\incremental\\mergeDebugResources\\merged.dir\\values-ta\\values-ta.xml",
+ "map": [
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\88c548461109b0c917067cfea58751b3\\appcompat-1.0.0-alpha1\\res\\values-ta\\values-ta.xml",
+ "from": {
+ "startLines": "2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19,20,21,22,23,24,25,26,27,28,29",
+ "startColumns": "4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4",
+ "startOffsets": "105,219,317,432,521,628,754,832,909,1009,1114,1210,1305,1412,1514,1618,1713,1815,1913,1995,2097,2201,2298,2408,2510,2617,2774,2874",
+ "endColumns": "113,97,114,88,106,125,77,76,99,104,95,94,106,101,103,94,101,97,81,101,103,96,109,101,106,156,99,79",
+ "endOffsets": "214,312,427,516,623,749,827,904,1004,1109,1205,1300,1407,1509,1613,1708,1810,1908,1990,2092,2196,2293,2403,2505,2612,2769,2869,2949"
+ }
+ },
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\6d11613c3b6a00a9ea456b5609ec43f7\\core-1.0.0\\res\\values-ta\\values-ta.xml",
+ "from": {
+ "startLines": "2",
+ "startColumns": "4",
+ "startOffsets": "55",
+ "endColumns": "100",
+ "endOffsets": "151"
+ },
+ "to": {
+ "startLines": "30",
+ "startColumns": "4",
+ "startOffsets": "2954",
+ "endColumns": "100",
+ "endOffsets": "3050"
+ }
+ }
+ ]
+ }
+ ]
+}
\ No newline at end of file
diff --git a/src/src/app/build/intermediates/blame/res/debug/multi-v2/values-te.json b/src/src/app/build/intermediates/blame/res/debug/multi-v2/values-te.json
new file mode 100644
index 0000000..d3547bb
--- /dev/null
+++ b/src/src/app/build/intermediates/blame/res/debug/multi-v2/values-te.json
@@ -0,0 +1,36 @@
+{
+ "logs": [
+ {
+ "outputFile": "E:\\Note\\src\\app\\build\\intermediates\\incremental\\mergeDebugResources\\merged.dir\\values-te\\values-te.xml",
+ "map": [
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\88c548461109b0c917067cfea58751b3\\appcompat-1.0.0-alpha1\\res\\values-te\\values-te.xml",
+ "from": {
+ "startLines": "2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19,20,21,22,23,24,25,26,27,28,29",
+ "startColumns": "4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4",
+ "startOffsets": "105,219,328,439,529,634,759,841,923,1014,1107,1203,1297,1398,1491,1586,1681,1772,1863,1947,2060,2168,2267,2378,2480,2597,2763,2864",
+ "endColumns": "113,108,110,89,104,124,81,81,90,92,95,93,100,92,94,94,90,90,83,112,107,98,110,101,116,165,100,81",
+ "endOffsets": "214,323,434,524,629,754,836,918,1009,1102,1198,1292,1393,1486,1581,1676,1767,1858,1942,2055,2163,2262,2373,2475,2592,2758,2859,2941"
+ }
+ },
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\6d11613c3b6a00a9ea456b5609ec43f7\\core-1.0.0\\res\\values-te\\values-te.xml",
+ "from": {
+ "startLines": "2",
+ "startColumns": "4",
+ "startOffsets": "55",
+ "endColumns": "100",
+ "endOffsets": "151"
+ },
+ "to": {
+ "startLines": "30",
+ "startColumns": "4",
+ "startOffsets": "2946",
+ "endColumns": "100",
+ "endOffsets": "3042"
+ }
+ }
+ ]
+ }
+ ]
+}
\ No newline at end of file
diff --git a/src/src/app/build/intermediates/blame/res/debug/multi-v2/values-th.json b/src/src/app/build/intermediates/blame/res/debug/multi-v2/values-th.json
new file mode 100644
index 0000000..5aada2e
--- /dev/null
+++ b/src/src/app/build/intermediates/blame/res/debug/multi-v2/values-th.json
@@ -0,0 +1,36 @@
+{
+ "logs": [
+ {
+ "outputFile": "E:\\Note\\src\\app\\build\\intermediates\\incremental\\mergeDebugResources\\merged.dir\\values-th\\values-th.xml",
+ "map": [
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\88c548461109b0c917067cfea58751b3\\appcompat-1.0.0-alpha1\\res\\values-th\\values-th.xml",
+ "from": {
+ "startLines": "2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19,20,21,22,23,24,25,26,27,28,29",
+ "startColumns": "4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4",
+ "startOffsets": "105,210,308,416,505,607,717,794,872,963,1056,1152,1246,1347,1440,1535,1629,1720,1811,1892,2000,2104,2202,2310,2415,2516,2669,2764",
+ "endColumns": "104,97,107,88,101,109,76,77,90,92,95,93,100,92,94,93,90,90,80,107,103,97,107,104,100,152,94,80",
+ "endOffsets": "205,303,411,500,602,712,789,867,958,1051,1147,1241,1342,1435,1530,1624,1715,1806,1887,1995,2099,2197,2305,2410,2511,2664,2759,2840"
+ }
+ },
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\6d11613c3b6a00a9ea456b5609ec43f7\\core-1.0.0\\res\\values-th\\values-th.xml",
+ "from": {
+ "startLines": "2",
+ "startColumns": "4",
+ "startOffsets": "55",
+ "endColumns": "100",
+ "endOffsets": "151"
+ },
+ "to": {
+ "startLines": "30",
+ "startColumns": "4",
+ "startOffsets": "2845",
+ "endColumns": "100",
+ "endOffsets": "2941"
+ }
+ }
+ ]
+ }
+ ]
+}
\ No newline at end of file
diff --git a/src/src/app/build/intermediates/blame/res/debug/multi-v2/values-tl.json b/src/src/app/build/intermediates/blame/res/debug/multi-v2/values-tl.json
new file mode 100644
index 0000000..17daf1a
--- /dev/null
+++ b/src/src/app/build/intermediates/blame/res/debug/multi-v2/values-tl.json
@@ -0,0 +1,36 @@
+{
+ "logs": [
+ {
+ "outputFile": "E:\\Note\\src\\app\\build\\intermediates\\incremental\\mergeDebugResources\\merged.dir\\values-tl\\values-tl.xml",
+ "map": [
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\88c548461109b0c917067cfea58751b3\\appcompat-1.0.0-alpha1\\res\\values-tl\\values-tl.xml",
+ "from": {
+ "startLines": "2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19,20,21,22,23,24,25,26,27,28,29",
+ "startColumns": "4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4",
+ "startOffsets": "105,224,332,449,537,643,764,843,921,1012,1105,1201,1295,1396,1489,1584,1678,1769,1860,1944,2053,2164,2265,2375,2492,2600,2763,2865",
+ "endColumns": "118,107,116,87,105,120,78,77,90,92,95,93,100,92,94,93,90,90,83,108,110,100,109,116,107,162,101,83",
+ "endOffsets": "219,327,444,532,638,759,838,916,1007,1100,1196,1290,1391,1484,1579,1673,1764,1855,1939,2048,2159,2260,2370,2487,2595,2758,2860,2944"
+ }
+ },
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\6d11613c3b6a00a9ea456b5609ec43f7\\core-1.0.0\\res\\values-tl\\values-tl.xml",
+ "from": {
+ "startLines": "2",
+ "startColumns": "4",
+ "startOffsets": "55",
+ "endColumns": "100",
+ "endOffsets": "151"
+ },
+ "to": {
+ "startLines": "30",
+ "startColumns": "4",
+ "startOffsets": "2949",
+ "endColumns": "100",
+ "endOffsets": "3045"
+ }
+ }
+ ]
+ }
+ ]
+}
\ No newline at end of file
diff --git a/src/src/app/build/intermediates/blame/res/debug/multi-v2/values-tr.json b/src/src/app/build/intermediates/blame/res/debug/multi-v2/values-tr.json
new file mode 100644
index 0000000..ae6d46c
--- /dev/null
+++ b/src/src/app/build/intermediates/blame/res/debug/multi-v2/values-tr.json
@@ -0,0 +1,36 @@
+{
+ "logs": [
+ {
+ "outputFile": "E:\\Note\\src\\app\\build\\intermediates\\incremental\\mergeDebugResources\\merged.dir\\values-tr\\values-tr.xml",
+ "map": [
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\6d11613c3b6a00a9ea456b5609ec43f7\\core-1.0.0\\res\\values-tr\\values-tr.xml",
+ "from": {
+ "startLines": "2",
+ "startColumns": "4",
+ "startOffsets": "55",
+ "endColumns": "100",
+ "endOffsets": "151"
+ },
+ "to": {
+ "startLines": "30",
+ "startColumns": "4",
+ "startOffsets": "2865",
+ "endColumns": "100",
+ "endOffsets": "2961"
+ }
+ },
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\88c548461109b0c917067cfea58751b3\\appcompat-1.0.0-alpha1\\res\\values-tr\\values-tr.xml",
+ "from": {
+ "startLines": "2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19,20,21,22,23,24,25,26,27,28,29",
+ "startColumns": "4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4",
+ "startOffsets": "105,210,309,421,506,612,732,811,887,978,1071,1164,1258,1356,1449,1551,1646,1737,1828,1907,2014,2119,2215,2322,2424,2532,2688,2786",
+ "endColumns": "104,98,111,84,105,119,78,75,90,92,92,93,97,92,101,94,90,90,78,106,104,95,106,101,107,155,97,78",
+ "endOffsets": "205,304,416,501,607,727,806,882,973,1066,1159,1253,1351,1444,1546,1641,1732,1823,1902,2009,2114,2210,2317,2419,2527,2683,2781,2860"
+ }
+ }
+ ]
+ }
+ ]
+}
\ No newline at end of file
diff --git a/src/src/app/build/intermediates/blame/res/debug/multi-v2/values-uk.json b/src/src/app/build/intermediates/blame/res/debug/multi-v2/values-uk.json
new file mode 100644
index 0000000..802e310
--- /dev/null
+++ b/src/src/app/build/intermediates/blame/res/debug/multi-v2/values-uk.json
@@ -0,0 +1,36 @@
+{
+ "logs": [
+ {
+ "outputFile": "E:\\Note\\src\\app\\build\\intermediates\\incremental\\mergeDebugResources\\merged.dir\\values-uk\\values-uk.xml",
+ "map": [
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\6d11613c3b6a00a9ea456b5609ec43f7\\core-1.0.0\\res\\values-uk\\values-uk.xml",
+ "from": {
+ "startLines": "2",
+ "startColumns": "4",
+ "startOffsets": "55",
+ "endColumns": "100",
+ "endOffsets": "151"
+ },
+ "to": {
+ "startLines": "30",
+ "startColumns": "4",
+ "startOffsets": "2900",
+ "endColumns": "100",
+ "endOffsets": "2996"
+ }
+ },
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\88c548461109b0c917067cfea58751b3\\appcompat-1.0.0-alpha1\\res\\values-uk\\values-uk.xml",
+ "from": {
+ "startLines": "2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19,20,21,22,23,24,25,26,27,28,29",
+ "startColumns": "4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4",
+ "startOffsets": "105,215,317,423,509,617,735,814,894,985,1078,1174,1268,1369,1462,1557,1652,1743,1834,1915,2021,2128,2226,2334,2440,2549,2719,2819",
+ "endColumns": "109,101,105,85,107,117,78,79,90,92,95,93,100,92,94,94,90,90,80,105,106,97,107,105,108,169,99,80",
+ "endOffsets": "210,312,418,504,612,730,809,889,980,1073,1169,1263,1364,1457,1552,1647,1738,1829,1910,2016,2123,2221,2329,2435,2544,2714,2814,2895"
+ }
+ }
+ ]
+ }
+ ]
+}
\ No newline at end of file
diff --git a/src/src/app/build/intermediates/blame/res/debug/multi-v2/values-ur.json b/src/src/app/build/intermediates/blame/res/debug/multi-v2/values-ur.json
new file mode 100644
index 0000000..7b25a15
--- /dev/null
+++ b/src/src/app/build/intermediates/blame/res/debug/multi-v2/values-ur.json
@@ -0,0 +1,36 @@
+{
+ "logs": [
+ {
+ "outputFile": "E:\\Note\\src\\app\\build\\intermediates\\incremental\\mergeDebugResources\\merged.dir\\values-ur\\values-ur.xml",
+ "map": [
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\88c548461109b0c917067cfea58751b3\\appcompat-1.0.0-alpha1\\res\\values-ur\\values-ur.xml",
+ "from": {
+ "startLines": "2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19,20,21,22,23,24,25,26,27,28,29",
+ "startColumns": "4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4",
+ "startOffsets": "105,215,321,430,516,620,740,816,892,984,1078,1174,1268,1370,1464,1560,1654,1746,1838,1923,2031,2140,2242,2353,2453,2561,2726,2824",
+ "endColumns": "109,105,108,85,103,119,75,75,91,93,95,93,101,93,95,93,91,91,84,107,108,101,110,99,107,164,97,79",
+ "endOffsets": "210,316,425,511,615,735,811,887,979,1073,1169,1263,1365,1459,1555,1649,1741,1833,1918,2026,2135,2237,2348,2448,2556,2721,2819,2899"
+ }
+ },
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\6d11613c3b6a00a9ea456b5609ec43f7\\core-1.0.0\\res\\values-ur\\values-ur.xml",
+ "from": {
+ "startLines": "2",
+ "startColumns": "4",
+ "startOffsets": "55",
+ "endColumns": "100",
+ "endOffsets": "151"
+ },
+ "to": {
+ "startLines": "30",
+ "startColumns": "4",
+ "startOffsets": "2904",
+ "endColumns": "100",
+ "endOffsets": "3000"
+ }
+ }
+ ]
+ }
+ ]
+}
\ No newline at end of file
diff --git a/src/src/app/build/intermediates/blame/res/debug/multi-v2/values-uz.json b/src/src/app/build/intermediates/blame/res/debug/multi-v2/values-uz.json
new file mode 100644
index 0000000..528ef05
--- /dev/null
+++ b/src/src/app/build/intermediates/blame/res/debug/multi-v2/values-uz.json
@@ -0,0 +1,36 @@
+{
+ "logs": [
+ {
+ "outputFile": "E:\\Note\\src\\app\\build\\intermediates\\incremental\\mergeDebugResources\\merged.dir\\values-uz\\values-uz.xml",
+ "map": [
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\6d11613c3b6a00a9ea456b5609ec43f7\\core-1.0.0\\res\\values-uz\\values-uz.xml",
+ "from": {
+ "startLines": "2",
+ "startColumns": "4",
+ "startOffsets": "55",
+ "endColumns": "100",
+ "endOffsets": "151"
+ },
+ "to": {
+ "startLines": "30",
+ "startColumns": "4",
+ "startOffsets": "2889",
+ "endColumns": "100",
+ "endOffsets": "2985"
+ }
+ },
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\88c548461109b0c917067cfea58751b3\\appcompat-1.0.0-alpha1\\res\\values-uz\\values-uz.xml",
+ "from": {
+ "startLines": "2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19,20,21,22,23,24,25,26,27,28,29",
+ "startColumns": "4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4",
+ "startOffsets": "105,210,314,428,514,614,730,810,889,980,1073,1169,1263,1358,1451,1546,1641,1732,1824,1908,2017,2124,2225,2333,2438,2545,2706,2805",
+ "endColumns": "104,103,113,85,99,115,79,78,90,92,95,93,94,92,94,94,90,91,83,108,106,100,107,104,106,160,98,83",
+ "endOffsets": "205,309,423,509,609,725,805,884,975,1068,1164,1258,1353,1446,1541,1636,1727,1819,1903,2012,2119,2220,2328,2433,2540,2701,2800,2884"
+ }
+ }
+ ]
+ }
+ ]
+}
\ No newline at end of file
diff --git a/src/src/app/build/intermediates/blame/res/debug/multi-v2/values-v16.json b/src/src/app/build/intermediates/blame/res/debug/multi-v2/values-v16.json
new file mode 100644
index 0000000..ca61ffe
--- /dev/null
+++ b/src/src/app/build/intermediates/blame/res/debug/multi-v2/values-v16.json
@@ -0,0 +1,38 @@
+{
+ "logs": [
+ {
+ "outputFile": "E:\\Note\\src\\app\\build\\intermediates\\incremental\\mergeDebugResources\\merged.dir\\values-v16\\values-v16.xml",
+ "map": [
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\88c548461109b0c917067cfea58751b3\\appcompat-1.0.0-alpha1\\res\\values-v16\\values-v16.xml",
+ "from": {
+ "startLines": "2",
+ "startColumns": "4",
+ "startOffsets": "55",
+ "endLines": "5",
+ "endColumns": "12",
+ "endOffsets": "223"
+ },
+ "to": {
+ "startLines": "3",
+ "startColumns": "4",
+ "startOffsets": "121",
+ "endLines": "6",
+ "endColumns": "12",
+ "endOffsets": "289"
+ }
+ },
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\6d11613c3b6a00a9ea456b5609ec43f7\\core-1.0.0\\res\\values-v16\\values-v16.xml",
+ "from": {
+ "startLines": "2",
+ "startColumns": "4",
+ "startOffsets": "55",
+ "endColumns": "65",
+ "endOffsets": "116"
+ }
+ }
+ ]
+ }
+ ]
+}
\ No newline at end of file
diff --git a/src/src/app/build/intermediates/blame/res/debug/multi-v2/values-v17.json b/src/src/app/build/intermediates/blame/res/debug/multi-v2/values-v17.json
new file mode 100644
index 0000000..b6c48de
--- /dev/null
+++ b/src/src/app/build/intermediates/blame/res/debug/multi-v2/values-v17.json
@@ -0,0 +1,20 @@
+{
+ "logs": [
+ {
+ "outputFile": "E:\\Note\\src\\app\\build\\intermediates\\incremental\\mergeDebugResources\\merged.dir\\values-v17\\values-v17.xml",
+ "map": [
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\88c548461109b0c917067cfea58751b3\\appcompat-1.0.0-alpha1\\res\\values-v17\\values-v17.xml",
+ "from": {
+ "startLines": "2,5,9,12,15,18,22,25,29,33,37,40,43,46,50,53,57",
+ "startColumns": "4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4",
+ "startOffsets": "55,228,456,614,764,936,1161,1331,1559,1783,2025,2196,2370,2539,2812,3012,3216",
+ "endLines": "4,8,11,14,17,21,24,28,32,36,39,42,45,49,52,56,60",
+ "endColumns": "12,12,12,12,12,12,12,12,12,12,12,12,12,12,12,12,12",
+ "endOffsets": "223,451,609,759,931,1156,1326,1554,1778,2020,2191,2365,2534,2807,3007,3211,3540"
+ }
+ }
+ ]
+ }
+ ]
+}
\ No newline at end of file
diff --git a/src/src/app/build/intermediates/blame/res/debug/multi-v2/values-v18.json b/src/src/app/build/intermediates/blame/res/debug/multi-v2/values-v18.json
new file mode 100644
index 0000000..e5812d3
--- /dev/null
+++ b/src/src/app/build/intermediates/blame/res/debug/multi-v2/values-v18.json
@@ -0,0 +1,19 @@
+{
+ "logs": [
+ {
+ "outputFile": "E:\\Note\\src\\app\\build\\intermediates\\incremental\\mergeDebugResources\\merged.dir\\values-v18\\values-v18.xml",
+ "map": [
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\88c548461109b0c917067cfea58751b3\\appcompat-1.0.0-alpha1\\res\\values-v18\\values-v18.xml",
+ "from": {
+ "startLines": "2",
+ "startColumns": "4",
+ "startOffsets": "55",
+ "endColumns": "48",
+ "endOffsets": "99"
+ }
+ }
+ ]
+ }
+ ]
+}
\ No newline at end of file
diff --git a/src/src/app/build/intermediates/blame/res/debug/multi-v2/values-v21.json b/src/src/app/build/intermediates/blame/res/debug/multi-v2/values-v21.json
new file mode 100644
index 0000000..fff26e7
--- /dev/null
+++ b/src/src/app/build/intermediates/blame/res/debug/multi-v2/values-v21.json
@@ -0,0 +1,66 @@
+{
+ "logs": [
+ {
+ "outputFile": "E:\\Note\\src\\app\\build\\intermediates\\incremental\\mergeDebugResources\\merged.dir\\values-v21\\values-v21.xml",
+ "map": [
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\88c548461109b0c917067cfea58751b3\\appcompat-1.0.0-alpha1\\res\\values-v21\\values-v21.xml",
+ "from": {
+ "startLines": "2,3,4,5,6,7,8,9,10,11,12,13,14,15,17,19,20,21,22,24,26,27,28,29,30,32,34,36,38,40,42,43,48,50,52,53,54,56,58,59,60,61,62,63,107,110,154,157,160,162,164,166,169,171,174,175,176,179,180,181,182,183,184,187,188,190,192,194,196,200,202,203,204,205,207,211,213,215,216,217,218,219,221,222,223,233,234,235,247",
+ "startColumns": "4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4",
+ "startOffsets": "55,146,249,352,457,564,673,782,891,1000,1109,1216,1319,1438,1593,1748,1853,1974,2075,2222,2363,2466,2585,2692,2795,2950,3121,3270,3435,3592,3743,3862,4234,4383,4532,4644,4791,4944,5091,5166,5255,5342,5443,5546,8614,8799,11879,12076,12275,12398,12521,12634,12817,12948,13149,13238,13349,13582,13683,13778,13901,14030,14147,14324,14423,14558,14701,14836,14955,15156,15275,15368,15479,15535,15642,15837,15948,16081,16176,16267,16358,16475,16614,16685,16768,17448,17505,17563,18257",
+ "endLines": "2,3,4,5,6,7,8,9,10,11,12,13,14,16,18,19,20,21,23,25,26,27,28,29,31,33,35,37,39,41,42,47,49,51,52,53,55,57,58,59,60,61,62,106,109,153,156,159,161,163,165,168,170,173,174,175,178,179,180,181,182,183,186,187,189,191,193,195,199,201,202,203,204,206,210,212,214,215,216,217,218,220,221,222,232,233,234,246,258",
+ "endColumns": "90,102,102,104,106,108,108,108,108,108,106,102,118,12,12,104,120,100,12,12,102,118,106,102,12,12,12,12,12,12,118,12,12,12,111,146,12,12,74,88,86,100,102,12,12,12,12,12,12,12,12,12,12,12,88,110,12,100,94,122,128,116,12,98,12,12,12,12,12,12,92,110,55,12,12,12,12,94,90,90,116,12,70,82,12,56,57,12,12",
+ "endOffsets": "141,244,347,452,559,668,777,886,995,1104,1211,1314,1433,1588,1743,1848,1969,2070,2217,2358,2461,2580,2687,2790,2945,3116,3265,3430,3587,3738,3857,4229,4378,4527,4639,4786,4939,5086,5161,5250,5337,5438,5541,8609,8794,11874,12071,12270,12393,12516,12629,12812,12943,13144,13233,13344,13577,13678,13773,13896,14025,14142,14319,14418,14553,14696,14831,14950,15151,15270,15363,15474,15530,15637,15832,15943,16076,16171,16262,16353,16470,16609,16680,16763,17443,17500,17558,18252,18958"
+ },
+ "to": {
+ "startLines": "6,7,8,9,10,11,12,13,14,15,16,17,18,19,21,23,24,25,26,28,30,31,32,33,34,36,38,40,42,44,46,47,52,54,56,57,58,60,62,63,64,65,66,67,111,114,158,161,164,166,168,170,173,175,178,179,180,183,184,185,186,187,188,191,192,194,196,198,200,204,206,207,208,209,211,215,217,219,220,221,222,223,225,226,227,237,238,239,251",
+ "startColumns": "4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4",
+ "startOffsets": "354,445,548,651,756,863,972,1081,1190,1299,1408,1515,1618,1737,1892,2047,2152,2273,2374,2521,2662,2765,2884,2991,3094,3249,3420,3569,3734,3891,4042,4161,4533,4682,4831,4943,5090,5243,5390,5465,5554,5641,5742,5845,8913,9098,12178,12375,12574,12697,12820,12933,13116,13247,13448,13537,13648,13881,13982,14077,14200,14329,14446,14623,14722,14857,15000,15135,15254,15455,15574,15667,15778,15834,15941,16136,16247,16380,16475,16566,16657,16774,16913,16984,17067,17747,17804,17862,18556",
+ "endLines": "6,7,8,9,10,11,12,13,14,15,16,17,18,20,22,23,24,25,27,29,30,31,32,33,35,37,39,41,43,45,46,51,53,55,56,57,59,61,62,63,64,65,66,110,113,157,160,163,165,167,169,172,174,177,178,179,182,183,184,185,186,187,190,191,193,195,197,199,203,205,206,207,208,210,214,216,218,219,220,221,222,224,225,226,236,237,238,250,262",
+ "endColumns": "90,102,102,104,106,108,108,108,108,108,106,102,118,12,12,104,120,100,12,12,102,118,106,102,12,12,12,12,12,12,118,12,12,12,111,146,12,12,74,88,86,100,102,12,12,12,12,12,12,12,12,12,12,12,88,110,12,100,94,122,128,116,12,98,12,12,12,12,12,12,92,110,55,12,12,12,12,94,90,90,116,12,70,82,12,56,57,12,12",
+ "endOffsets": "440,543,646,751,858,967,1076,1185,1294,1403,1510,1613,1732,1887,2042,2147,2268,2369,2516,2657,2760,2879,2986,3089,3244,3415,3564,3729,3886,4037,4156,4528,4677,4826,4938,5085,5238,5385,5460,5549,5636,5737,5840,8908,9093,12173,12370,12569,12692,12815,12928,13111,13242,13443,13532,13643,13876,13977,14072,14195,14324,14441,14618,14717,14852,14995,15130,15249,15450,15569,15662,15773,15829,15936,16131,16242,16375,16470,16561,16652,16769,16908,16979,17062,17742,17799,17857,18551,19257"
+ }
+ },
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\6d11613c3b6a00a9ea456b5609ec43f7\\core-1.0.0\\res\\values-v21\\values-v21.xml",
+ "from": {
+ "startLines": "2,3,4,5,6,7,8,9,10,13",
+ "startColumns": "4,4,4,4,4,4,4,4,4,4",
+ "startOffsets": "55,159,223,290,354,470,596,722,850,1022",
+ "endLines": "2,3,4,5,6,7,8,9,12,17",
+ "endColumns": "103,63,66,63,115,125,125,127,12,12",
+ "endOffsets": "154,218,285,349,465,591,717,845,1017,1355"
+ },
+ "to": {
+ "startLines": "2,3,4,5,263,264,271,275,279,282",
+ "startColumns": "4,4,4,4,4,4,4,4,4,4",
+ "startOffsets": "55,159,223,290,19262,19378,19835,20129,20424,20596",
+ "endLines": "2,3,4,5,263,264,271,275,281,286",
+ "endColumns": "103,63,66,63,115,125,125,127,12,12",
+ "endOffsets": "154,218,285,349,19373,19499,19956,20252,20591,20929"
+ }
+ },
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\702974eead929cb167f132efe0eabb04\\media-1.0.0\\res\\values-v21\\values-v21.xml",
+ "from": {
+ "startLines": "2,5,8,11",
+ "startColumns": "4,4,4,4",
+ "startOffsets": "55,223,386,554",
+ "endLines": "4,7,10,13",
+ "endColumns": "12,12,12,12",
+ "endOffsets": "218,381,549,716"
+ },
+ "to": {
+ "startLines": "265,268,272,276",
+ "startColumns": "4,4,4,4",
+ "startOffsets": "19504,19672,19961,20257",
+ "endLines": "267,270,274,278",
+ "endColumns": "12,12,12,12",
+ "endOffsets": "19667,19830,20124,20419"
+ }
+ }
+ ]
+ }
+ ]
+}
\ No newline at end of file
diff --git a/src/src/app/build/intermediates/blame/res/debug/multi-v2/values-v22.json b/src/src/app/build/intermediates/blame/res/debug/multi-v2/values-v22.json
new file mode 100644
index 0000000..8e6b4dc
--- /dev/null
+++ b/src/src/app/build/intermediates/blame/res/debug/multi-v2/values-v22.json
@@ -0,0 +1,20 @@
+{
+ "logs": [
+ {
+ "outputFile": "E:\\Note\\src\\app\\build\\intermediates\\incremental\\mergeDebugResources\\merged.dir\\values-v22\\values-v22.xml",
+ "map": [
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\88c548461109b0c917067cfea58751b3\\appcompat-1.0.0-alpha1\\res\\values-v22\\values-v22.xml",
+ "from": {
+ "startLines": "2,3,4,9",
+ "startColumns": "4,4,4,4",
+ "startOffsets": "55,130,217,553",
+ "endLines": "2,3,8,13",
+ "endColumns": "74,86,12,12",
+ "endOffsets": "125,212,548,896"
+ }
+ }
+ ]
+ }
+ ]
+}
\ No newline at end of file
diff --git a/src/src/app/build/intermediates/blame/res/debug/multi-v2/values-v23.json b/src/src/app/build/intermediates/blame/res/debug/multi-v2/values-v23.json
new file mode 100644
index 0000000..f465e02
--- /dev/null
+++ b/src/src/app/build/intermediates/blame/res/debug/multi-v2/values-v23.json
@@ -0,0 +1,20 @@
+{
+ "logs": [
+ {
+ "outputFile": "E:\\Note\\src\\app\\build\\intermediates\\incremental\\mergeDebugResources\\merged.dir\\values-v23\\values-v23.xml",
+ "map": [
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\88c548461109b0c917067cfea58751b3\\appcompat-1.0.0-alpha1\\res\\values-v23\\values-v23.xml",
+ "from": {
+ "startLines": "2,3,4,5,6,19,32,33,34,35,36",
+ "startColumns": "4,4,4,4,4,4,4,4,4,4,4",
+ "startOffsets": "55,190,325,400,487,1277,2079,2206,2311,2426,2533",
+ "endLines": "2,3,4,5,18,31,32,33,34,35,36",
+ "endColumns": "134,134,74,86,12,12,126,104,114,106,112",
+ "endOffsets": "185,320,395,482,1272,2074,2201,2306,2421,2528,2641"
+ }
+ }
+ ]
+ }
+ ]
+}
\ No newline at end of file
diff --git a/src/src/app/build/intermediates/blame/res/debug/multi-v2/values-v24.json b/src/src/app/build/intermediates/blame/res/debug/multi-v2/values-v24.json
new file mode 100644
index 0000000..8dca346
--- /dev/null
+++ b/src/src/app/build/intermediates/blame/res/debug/multi-v2/values-v24.json
@@ -0,0 +1,36 @@
+{
+ "logs": [
+ {
+ "outputFile": "E:\\Note\\src\\app\\build\\intermediates\\incremental\\mergeDebugResources\\merged.dir\\values-v24\\values-v24.xml",
+ "map": [
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\702974eead929cb167f132efe0eabb04\\media-1.0.0\\res\\values-v24\\values-v24.xml",
+ "from": {
+ "startLines": "2,3,4,5",
+ "startColumns": "4,4,4,4",
+ "startOffsets": "55,121,182,248",
+ "endColumns": "65,60,65,66",
+ "endOffsets": "116,177,243,310"
+ },
+ "to": {
+ "startLines": "4,5,6,7",
+ "startColumns": "4,4,4,4",
+ "startOffsets": "347,413,474,540",
+ "endColumns": "65,60,65,66",
+ "endOffsets": "408,469,535,602"
+ }
+ },
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\88c548461109b0c917067cfea58751b3\\appcompat-1.0.0-alpha1\\res\\values-v24\\values-v24.xml",
+ "from": {
+ "startLines": "2,3",
+ "startColumns": "4,4",
+ "startOffsets": "55,212",
+ "endColumns": "156,134",
+ "endOffsets": "207,342"
+ }
+ }
+ ]
+ }
+ ]
+}
\ No newline at end of file
diff --git a/src/src/app/build/intermediates/blame/res/debug/multi-v2/values-v25.json b/src/src/app/build/intermediates/blame/res/debug/multi-v2/values-v25.json
new file mode 100644
index 0000000..c2ef8e6
--- /dev/null
+++ b/src/src/app/build/intermediates/blame/res/debug/multi-v2/values-v25.json
@@ -0,0 +1,20 @@
+{
+ "logs": [
+ {
+ "outputFile": "E:\\Note\\src\\app\\build\\intermediates\\incremental\\mergeDebugResources\\merged.dir\\values-v25\\values-v25.xml",
+ "map": [
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\88c548461109b0c917067cfea58751b3\\appcompat-1.0.0-alpha1\\res\\values-v25\\values-v25.xml",
+ "from": {
+ "startLines": "2,3,4,6",
+ "startColumns": "4,4,4,4",
+ "startOffsets": "55,126,209,308",
+ "endLines": "2,3,5,7",
+ "endColumns": "70,82,12,12",
+ "endOffsets": "121,204,303,414"
+ }
+ }
+ ]
+ }
+ ]
+}
\ No newline at end of file
diff --git a/src/src/app/build/intermediates/blame/res/debug/multi-v2/values-v26.json b/src/src/app/build/intermediates/blame/res/debug/multi-v2/values-v26.json
new file mode 100644
index 0000000..b5f8f75
--- /dev/null
+++ b/src/src/app/build/intermediates/blame/res/debug/multi-v2/values-v26.json
@@ -0,0 +1,20 @@
+{
+ "logs": [
+ {
+ "outputFile": "E:\\Note\\src\\app\\build\\intermediates\\incremental\\mergeDebugResources\\merged.dir\\values-v26\\values-v26.xml",
+ "map": [
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\88c548461109b0c917067cfea58751b3\\appcompat-1.0.0-alpha1\\res\\values-v26\\values-v26.xml",
+ "from": {
+ "startLines": "2,3,4,8,12,16",
+ "startColumns": "4,4,4,4,4,4",
+ "startOffsets": "55,130,217,431,657,896",
+ "endLines": "2,3,7,11,15,16",
+ "endColumns": "74,86,12,12,12,92",
+ "endOffsets": "125,212,426,652,891,984"
+ }
+ }
+ ]
+ }
+ ]
+}
\ No newline at end of file
diff --git a/src/src/app/build/intermediates/blame/res/debug/multi-v2/values-v28.json b/src/src/app/build/intermediates/blame/res/debug/multi-v2/values-v28.json
new file mode 100644
index 0000000..289bc50
--- /dev/null
+++ b/src/src/app/build/intermediates/blame/res/debug/multi-v2/values-v28.json
@@ -0,0 +1,20 @@
+{
+ "logs": [
+ {
+ "outputFile": "E:\\Note\\src\\app\\build\\intermediates\\incremental\\mergeDebugResources\\merged.dir\\values-v28\\values-v28.xml",
+ "map": [
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\88c548461109b0c917067cfea58751b3\\appcompat-1.0.0-alpha1\\res\\values-v28\\values-v28.xml",
+ "from": {
+ "startLines": "2,3,4,8",
+ "startColumns": "4,4,4,4",
+ "startOffsets": "55,130,217,447",
+ "endLines": "2,3,7,11",
+ "endColumns": "74,86,12,12",
+ "endOffsets": "125,212,442,684"
+ }
+ }
+ ]
+ }
+ ]
+}
\ No newline at end of file
diff --git a/src/src/app/build/intermediates/blame/res/debug/multi-v2/values-vi.json b/src/src/app/build/intermediates/blame/res/debug/multi-v2/values-vi.json
new file mode 100644
index 0000000..385ca6e
--- /dev/null
+++ b/src/src/app/build/intermediates/blame/res/debug/multi-v2/values-vi.json
@@ -0,0 +1,36 @@
+{
+ "logs": [
+ {
+ "outputFile": "E:\\Note\\src\\app\\build\\intermediates\\incremental\\mergeDebugResources\\merged.dir\\values-vi\\values-vi.xml",
+ "map": [
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\88c548461109b0c917067cfea58751b3\\appcompat-1.0.0-alpha1\\res\\values-vi\\values-vi.xml",
+ "from": {
+ "startLines": "2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19,20,21,22,23,24,25,26,27,28,29",
+ "startColumns": "4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4",
+ "startOffsets": "105,219,327,436,520,623,742,819,896,987,1080,1176,1270,1371,1464,1559,1657,1748,1839,1923,2027,2136,2237,2342,2456,2561,2718,2817",
+ "endColumns": "113,107,108,83,102,118,76,76,90,92,95,93,100,92,94,97,90,90,83,103,108,100,104,113,104,156,98,83",
+ "endOffsets": "214,322,431,515,618,737,814,891,982,1075,1171,1265,1366,1459,1554,1652,1743,1834,1918,2022,2131,2232,2337,2451,2556,2713,2812,2896"
+ }
+ },
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\6d11613c3b6a00a9ea456b5609ec43f7\\core-1.0.0\\res\\values-vi\\values-vi.xml",
+ "from": {
+ "startLines": "2",
+ "startColumns": "4",
+ "startOffsets": "55",
+ "endColumns": "100",
+ "endOffsets": "151"
+ },
+ "to": {
+ "startLines": "30",
+ "startColumns": "4",
+ "startOffsets": "2901",
+ "endColumns": "100",
+ "endOffsets": "2997"
+ }
+ }
+ ]
+ }
+ ]
+}
\ No newline at end of file
diff --git a/src/src/app/build/intermediates/blame/res/debug/multi-v2/values-watch-v20.json b/src/src/app/build/intermediates/blame/res/debug/multi-v2/values-watch-v20.json
new file mode 100644
index 0000000..5cc088f
--- /dev/null
+++ b/src/src/app/build/intermediates/blame/res/debug/multi-v2/values-watch-v20.json
@@ -0,0 +1,20 @@
+{
+ "logs": [
+ {
+ "outputFile": "E:\\Note\\src\\app\\build\\intermediates\\incremental\\mergeDebugResources\\merged.dir\\values-watch-v20\\values-watch-v20.xml",
+ "map": [
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\88c548461109b0c917067cfea58751b3\\appcompat-1.0.0-alpha1\\res\\values-watch-v20\\values-watch-v20.xml",
+ "from": {
+ "startLines": "2,5,8",
+ "startColumns": "4,4,4",
+ "startOffsets": "55,214,385",
+ "endLines": "4,7,10",
+ "endColumns": "12,12,12",
+ "endOffsets": "209,380,553"
+ }
+ }
+ ]
+ }
+ ]
+}
\ No newline at end of file
diff --git a/src/src/app/build/intermediates/blame/res/debug/multi-v2/values-watch-v21.json b/src/src/app/build/intermediates/blame/res/debug/multi-v2/values-watch-v21.json
new file mode 100644
index 0000000..70193f1
--- /dev/null
+++ b/src/src/app/build/intermediates/blame/res/debug/multi-v2/values-watch-v21.json
@@ -0,0 +1,20 @@
+{
+ "logs": [
+ {
+ "outputFile": "E:\\Note\\src\\app\\build\\intermediates\\incremental\\mergeDebugResources\\merged.dir\\values-watch-v21\\values-watch-v21.xml",
+ "map": [
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\88c548461109b0c917067cfea58751b3\\appcompat-1.0.0-alpha1\\res\\values-watch-v21\\values-watch-v21.xml",
+ "from": {
+ "startLines": "2,6,10",
+ "startColumns": "4,4,4",
+ "startOffsets": "55,271,499",
+ "endLines": "5,9,13",
+ "endColumns": "12,12,12",
+ "endOffsets": "266,494,724"
+ }
+ }
+ ]
+ }
+ ]
+}
\ No newline at end of file
diff --git a/src/src/app/build/intermediates/blame/res/debug/multi-v2/values-xlarge-v4.json b/src/src/app/build/intermediates/blame/res/debug/multi-v2/values-xlarge-v4.json
new file mode 100644
index 0000000..11d8fc8
--- /dev/null
+++ b/src/src/app/build/intermediates/blame/res/debug/multi-v2/values-xlarge-v4.json
@@ -0,0 +1,19 @@
+{
+ "logs": [
+ {
+ "outputFile": "E:\\Note\\src\\app\\build\\intermediates\\incremental\\mergeDebugResources\\merged.dir\\values-xlarge-v4\\values-xlarge-v4.xml",
+ "map": [
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\88c548461109b0c917067cfea58751b3\\appcompat-1.0.0-alpha1\\res\\values-xlarge-v4\\values-xlarge-v4.xml",
+ "from": {
+ "startLines": "2,3,4,5,6,7",
+ "startColumns": "4,4,4,4,4,4",
+ "startOffsets": "55,126,197,267,337,405",
+ "endColumns": "70,70,69,69,67,67",
+ "endOffsets": "121,192,262,332,400,468"
+ }
+ }
+ ]
+ }
+ ]
+}
\ No newline at end of file
diff --git a/src/src/app/build/intermediates/blame/res/debug/multi-v2/values-zh-rCN.json b/src/src/app/build/intermediates/blame/res/debug/multi-v2/values-zh-rCN.json
new file mode 100644
index 0000000..4efff66
--- /dev/null
+++ b/src/src/app/build/intermediates/blame/res/debug/multi-v2/values-zh-rCN.json
@@ -0,0 +1,81 @@
+{
+ "logs": [
+ {
+ "outputFile": "E:\\Note\\src\\app\\build\\intermediates\\incremental\\mergeDebugResources\\merged.dir\\values-zh-rCN\\values-zh-rCN.xml",
+ "map": [
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\6d11613c3b6a00a9ea456b5609ec43f7\\core-1.0.0\\res\\values-zh-rCN\\values-zh-rCN.xml",
+ "from": {
+ "startLines": "2",
+ "startColumns": "4",
+ "startOffsets": "55",
+ "endColumns": "100",
+ "endOffsets": "151"
+ },
+ "to": {
+ "startLines": "132",
+ "startColumns": "4",
+ "startOffsets": "8392",
+ "endColumns": "100",
+ "endOffsets": "8488"
+ }
+ },
+ {
+ "source": "E:\\Note\\src\\app\\src\\main\\res\\values-zh-rCN\\arrays.xml",
+ "from": {
+ "startLines": "18",
+ "startColumns": "4",
+ "startOffsets": "730",
+ "endLines": "21",
+ "endColumns": "19",
+ "endOffsets": "838"
+ },
+ "to": {
+ "startLines": "2",
+ "startColumns": "4",
+ "startOffsets": "105",
+ "endLines": "5",
+ "endColumns": "19",
+ "endOffsets": "210"
+ }
+ },
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\88c548461109b0c917067cfea58751b3\\appcompat-1.0.0-alpha1\\res\\values-zh-rCN\\values-zh-rCN.xml",
+ "from": {
+ "startLines": "2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19,20,21,22,23,24,25,26,27,28,29",
+ "startColumns": "4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4",
+ "startOffsets": "105,201,296,396,478,575,681,757,833,924,1017,1115,1211,1306,1399,1494,1586,1677,1768,1846,1942,2038,2133,2230,2325,2423,2572,2666",
+ "endColumns": "95,94,99,81,96,105,75,75,90,92,97,95,94,92,94,91,90,90,77,95,95,94,96,94,97,148,93,77",
+ "endOffsets": "196,291,391,473,570,676,752,828,919,1012,1110,1206,1301,1394,1489,1581,1672,1763,1841,1937,2033,2128,2225,2320,2418,2567,2661,2739"
+ },
+ "to": {
+ "startLines": "9,10,11,12,13,14,15,16,17,18,19,20,21,22,23,24,25,26,27,28,29,30,31,32,33,34,35,128",
+ "startColumns": "4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4",
+ "startOffsets": "384,480,575,675,757,854,960,1036,1112,1203,1296,1394,1490,1585,1678,1773,1865,1956,2047,2125,2221,2317,2412,2509,2604,2702,2851,8147",
+ "endColumns": "95,94,99,81,96,105,75,75,90,92,97,95,94,92,94,91,90,90,77,95,95,94,96,94,97,148,93,77",
+ "endOffsets": "475,570,670,752,849,955,1031,1107,1198,1291,1389,1485,1580,1673,1768,1860,1951,2042,2120,2216,2312,2407,2504,2599,2697,2846,2940,8220"
+ }
+ },
+ {
+ "source": "E:\\Note\\src\\app\\src\\main\\res\\values-zh-rCN\\strings.xml",
+ "from": {
+ "startLines": "134,84,83,82,81,32,33,34,125,126,25,133,132,29,39,24,27,90,91,89,88,87,103,102,101,93,73,42,43,94,85,127,80,23,21,76,22,51,57,62,52,72,71,70,66,65,63,64,67,68,58,79,69,77,56,61,60,59,75,55,74,53,54,78,41,47,49,46,48,45,44,38,37,110,109,112,124,117,116,118,119,121,120,111,115,113,114,108,122,123,131,129,128,130,28,40,92,100,105,104,106,26,99,98,97,96,35,36",
+ "startColumns": "4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4",
+ "startOffsets": "7171,4084,4017,3943,3892,1364,1405,1454,6713,6759,1101,7116,7065,1273,1743,1049,1187,4456,4525,4396,4330,4266,5200,5139,5075,4659,3455,1916,1970,4714,4158,6817,3832,995,885,3615,938,2354,2641,2892,2408,3394,3340,3288,3089,3040,2944,2993,3136,3184,2685,3772,3235,3659,2597,2844,2787,2731,3559,2552,3516,2459,2501,3712,1864,2175,2273,2127,2225,2079,2033,1691,1637,5582,5522,5725,6638,6041,5971,6106,6185,6370,6296,5658,5915,5783,5849,5472,6475,6559,7026,6917,6868,6963,1224,1806,4603,5015,5315,5256,5383,1142,4966,4920,4871,4819,1503,1570",
+ "endLines": "136,84,83,82,81,32,33,34,125,126,25,133,132,29,39,24,27,90,91,89,88,87,103,102,101,93,73,42,43,94,85,127,80,23,21,76,22,51,57,62,52,72,71,70,66,65,63,64,67,68,58,79,69,77,56,61,60,59,75,55,74,53,54,78,41,47,49,46,48,45,44,38,37,110,109,112,124,117,116,118,119,121,120,111,115,113,114,108,122,123,131,129,128,130,28,40,92,100,105,104,106,26,99,98,97,96,35,36",
+ "endColumns": "14,72,65,72,49,39,47,47,44,56,39,53,49,50,61,50,35,67,76,58,64,62,54,59,62,53,59,52,61,84,80,49,58,52,51,42,55,52,42,50,49,59,52,50,45,47,47,45,46,49,44,58,51,51,42,46,55,54,54,43,41,40,49,58,50,48,48,46,46,46,44,50,52,74,58,56,73,63,68,77,109,103,72,65,54,64,64,48,82,77,37,44,47,61,47,56,54,58,66,57,61,43,47,44,47,50,65,65",
+ "endOffsets": "7345,4152,4078,4011,3937,1399,1448,1497,6753,6811,1136,7165,7110,1319,1800,1095,1218,4519,4597,4450,4390,4324,5250,5194,5133,4708,3510,1964,2027,4794,4234,6862,3886,1043,932,3653,989,2402,2679,2938,2453,3449,3388,3334,3130,3083,2987,3034,3178,3229,2725,3826,3282,3706,2635,2886,2838,2781,3609,2591,3553,2495,2546,3766,1910,2219,2317,2169,2267,2121,2073,1737,1685,5652,5576,5777,6707,6100,6035,6179,6290,6469,6364,5719,5965,5843,5909,5516,6553,6632,7059,6957,6911,7020,1267,1858,4653,5069,5377,5309,5440,1181,5009,4960,4914,4865,1564,1631"
+ },
+ "to": {
+ "startLines": "6,36,37,38,39,40,41,42,43,44,45,46,47,48,49,50,51,52,53,54,55,56,57,58,59,60,61,62,63,64,65,66,67,68,69,70,71,72,73,74,75,76,77,78,79,80,81,82,83,84,85,86,87,88,89,90,91,92,93,94,95,96,97,98,99,100,101,102,103,104,105,106,107,108,109,110,111,112,113,114,115,116,117,118,119,120,121,122,123,124,125,126,127,129,130,131,133,134,135,136,137,138,139,140,141,142,143,144",
+ "startColumns": "4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4",
+ "startOffsets": "215,2945,3018,3084,3157,3207,3247,3295,3343,3388,3445,3485,3539,3589,3640,3702,3753,3789,3857,3934,3993,4058,4121,4176,4236,4299,4353,4413,4466,4528,4613,4694,4744,4803,4856,4908,4951,5007,5060,5103,5154,5204,5264,5317,5368,5414,5462,5510,5556,5603,5653,5698,5757,5809,5861,5904,5951,6007,6062,6117,6161,6203,6244,6294,6353,6404,6453,6502,6549,6596,6643,6688,6739,6792,6867,6926,6983,7057,7121,7190,7268,7378,7482,7555,7621,7676,7741,7806,7855,7938,8016,8054,8099,8225,8287,8335,8493,8548,8607,8674,8732,8794,8838,8886,8931,8979,9030,9096",
+ "endLines": "8,36,37,38,39,40,41,42,43,44,45,46,47,48,49,50,51,52,53,54,55,56,57,58,59,60,61,62,63,64,65,66,67,68,69,70,71,72,73,74,75,76,77,78,79,80,81,82,83,84,85,86,87,88,89,90,91,92,93,94,95,96,97,98,99,100,101,102,103,104,105,106,107,108,109,110,111,112,113,114,115,116,117,118,119,120,121,122,123,124,125,126,127,129,130,131,133,134,135,136,137,138,139,140,141,142,143,144",
+ "endColumns": "14,72,65,72,49,39,47,47,44,56,39,53,49,50,61,50,35,67,76,58,64,62,54,59,62,53,59,52,61,84,80,49,58,52,51,42,55,52,42,50,49,59,52,50,45,47,47,45,46,49,44,58,51,51,42,46,55,54,54,43,41,40,49,58,50,48,48,46,46,46,44,50,52,74,58,56,73,63,68,77,109,103,72,65,54,64,64,48,82,77,37,44,47,61,47,56,54,58,66,57,61,43,47,44,47,50,65,65",
+ "endOffsets": "379,3013,3079,3152,3202,3242,3290,3338,3383,3440,3480,3534,3584,3635,3697,3748,3784,3852,3929,3988,4053,4116,4171,4231,4294,4348,4408,4461,4523,4608,4689,4739,4798,4851,4903,4946,5002,5055,5098,5149,5199,5259,5312,5363,5409,5457,5505,5551,5598,5648,5693,5752,5804,5856,5899,5946,6002,6057,6112,6156,6198,6239,6289,6348,6399,6448,6497,6544,6591,6638,6683,6734,6787,6862,6921,6978,7052,7116,7185,7263,7373,7477,7550,7616,7671,7736,7801,7850,7933,8011,8049,8094,8142,8282,8330,8387,8543,8602,8669,8727,8789,8833,8881,8926,8974,9025,9091,9157"
+ }
+ }
+ ]
+ }
+ ]
+}
\ No newline at end of file
diff --git a/src/src/app/build/intermediates/blame/res/debug/multi-v2/values-zh-rHK.json b/src/src/app/build/intermediates/blame/res/debug/multi-v2/values-zh-rHK.json
new file mode 100644
index 0000000..4fe553d
--- /dev/null
+++ b/src/src/app/build/intermediates/blame/res/debug/multi-v2/values-zh-rHK.json
@@ -0,0 +1,36 @@
+{
+ "logs": [
+ {
+ "outputFile": "E:\\Note\\src\\app\\build\\intermediates\\incremental\\mergeDebugResources\\merged.dir\\values-zh-rHK\\values-zh-rHK.xml",
+ "map": [
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\88c548461109b0c917067cfea58751b3\\appcompat-1.0.0-alpha1\\res\\values-zh-rHK\\values-zh-rHK.xml",
+ "from": {
+ "startLines": "2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19,20,21,22,23,24,25,26,27,28,29",
+ "startColumns": "4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4",
+ "startOffsets": "105,200,293,393,475,572,680,756,832,924,1018,1110,1206,1302,1396,1492,1584,1676,1768,1846,1942,2038,2133,2230,2325,2423,2574,2668",
+ "endColumns": "94,92,99,81,96,107,75,75,91,93,91,95,95,93,95,91,91,91,77,95,95,94,96,94,97,150,93,77",
+ "endOffsets": "195,288,388,470,567,675,751,827,919,1013,1105,1201,1297,1391,1487,1579,1671,1763,1841,1937,2033,2128,2225,2320,2418,2569,2663,2741"
+ }
+ },
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\6d11613c3b6a00a9ea456b5609ec43f7\\core-1.0.0\\res\\values-zh-rHK\\values-zh-rHK.xml",
+ "from": {
+ "startLines": "2",
+ "startColumns": "4",
+ "startOffsets": "55",
+ "endColumns": "100",
+ "endOffsets": "151"
+ },
+ "to": {
+ "startLines": "30",
+ "startColumns": "4",
+ "startOffsets": "2746",
+ "endColumns": "100",
+ "endOffsets": "2842"
+ }
+ }
+ ]
+ }
+ ]
+}
\ No newline at end of file
diff --git a/src/src/app/build/intermediates/blame/res/debug/multi-v2/values-zh-rTW.json b/src/src/app/build/intermediates/blame/res/debug/multi-v2/values-zh-rTW.json
new file mode 100644
index 0000000..1d98adf
--- /dev/null
+++ b/src/src/app/build/intermediates/blame/res/debug/multi-v2/values-zh-rTW.json
@@ -0,0 +1,62 @@
+{
+ "logs": [
+ {
+ "outputFile": "E:\\Note\\src\\app\\build\\intermediates\\incremental\\mergeDebugResources\\merged.dir\\values-zh-rTW\\values-zh-rTW.xml",
+ "map": [
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\6d11613c3b6a00a9ea456b5609ec43f7\\core-1.0.0\\res\\values-zh-rTW\\values-zh-rTW.xml",
+ "from": {
+ "startLines": "2",
+ "startColumns": "4",
+ "startOffsets": "55",
+ "endColumns": "100",
+ "endOffsets": "151"
+ },
+ "to": {
+ "startLines": "34",
+ "startColumns": "4",
+ "startOffsets": "2863",
+ "endColumns": "100",
+ "endOffsets": "2959"
+ }
+ },
+ {
+ "source": "E:\\Note\\src\\app\\src\\main\\res\\values-zh-rTW\\arrays.xml",
+ "from": {
+ "startLines": "18",
+ "startColumns": "4",
+ "startOffsets": "730",
+ "endLines": "21",
+ "endColumns": "19",
+ "endOffsets": "838"
+ },
+ "to": {
+ "startLines": "2",
+ "startColumns": "4",
+ "startOffsets": "105",
+ "endLines": "5",
+ "endColumns": "19",
+ "endOffsets": "210"
+ }
+ },
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\88c548461109b0c917067cfea58751b3\\appcompat-1.0.0-alpha1\\res\\values-zh-rTW\\values-zh-rTW.xml",
+ "from": {
+ "startLines": "2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19,20,21,22,23,24,25,26,27,28,29",
+ "startColumns": "4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4",
+ "startOffsets": "105,200,293,393,475,572,680,756,832,924,1018,1116,1212,1308,1402,1498,1590,1682,1774,1852,1948,2044,2139,2236,2331,2431,2581,2675",
+ "endColumns": "94,92,99,81,96,107,75,75,91,93,97,95,95,93,95,91,91,91,77,95,95,94,96,94,99,149,93,77",
+ "endOffsets": "195,288,388,470,567,675,751,827,919,1013,1111,1207,1303,1397,1493,1585,1677,1769,1847,1943,2039,2134,2231,2326,2426,2576,2670,2748"
+ },
+ "to": {
+ "startLines": "6,7,8,9,10,11,12,13,14,15,16,17,18,19,20,21,22,23,24,25,26,27,28,29,30,31,32,33",
+ "startColumns": "4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4",
+ "startOffsets": "215,310,403,503,585,682,790,866,942,1034,1128,1226,1322,1418,1512,1608,1700,1792,1884,1962,2058,2154,2249,2346,2441,2541,2691,2785",
+ "endColumns": "94,92,99,81,96,107,75,75,91,93,97,95,95,93,95,91,91,91,77,95,95,94,96,94,99,149,93,77",
+ "endOffsets": "305,398,498,580,677,785,861,937,1029,1123,1221,1317,1413,1507,1603,1695,1787,1879,1957,2053,2149,2244,2341,2436,2536,2686,2780,2858"
+ }
+ }
+ ]
+ }
+ ]
+}
\ No newline at end of file
diff --git a/src/src/app/build/intermediates/blame/res/debug/multi-v2/values-zu.json b/src/src/app/build/intermediates/blame/res/debug/multi-v2/values-zu.json
new file mode 100644
index 0000000..8f208d4
--- /dev/null
+++ b/src/src/app/build/intermediates/blame/res/debug/multi-v2/values-zu.json
@@ -0,0 +1,36 @@
+{
+ "logs": [
+ {
+ "outputFile": "E:\\Note\\src\\app\\build\\intermediates\\incremental\\mergeDebugResources\\merged.dir\\values-zu\\values-zu.xml",
+ "map": [
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\88c548461109b0c917067cfea58751b3\\appcompat-1.0.0-alpha1\\res\\values-zu\\values-zu.xml",
+ "from": {
+ "startLines": "2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19,20,21,22,23,24,25,26,27,28,29",
+ "startColumns": "4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4",
+ "startOffsets": "105,213,320,434,522,625,752,832,912,1003,1096,1190,1284,1385,1478,1573,1667,1758,1851,1937,2041,2147,2245,2352,2458,2564,2721,2817",
+ "endColumns": "107,106,113,87,102,126,79,79,90,92,93,93,100,92,94,93,90,92,85,103,105,97,106,105,105,156,95,80",
+ "endOffsets": "208,315,429,517,620,747,827,907,998,1091,1185,1279,1380,1473,1568,1662,1753,1846,1932,2036,2142,2240,2347,2453,2559,2716,2812,2893"
+ }
+ },
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\6d11613c3b6a00a9ea456b5609ec43f7\\core-1.0.0\\res\\values-zu\\values-zu.xml",
+ "from": {
+ "startLines": "2",
+ "startColumns": "4",
+ "startOffsets": "55",
+ "endColumns": "100",
+ "endOffsets": "151"
+ },
+ "to": {
+ "startLines": "30",
+ "startColumns": "4",
+ "startOffsets": "2898",
+ "endColumns": "100",
+ "endOffsets": "2994"
+ }
+ }
+ ]
+ }
+ ]
+}
\ No newline at end of file
diff --git a/src/src/app/build/intermediates/blame/res/debug/multi-v2/values.json b/src/src/app/build/intermediates/blame/res/debug/multi-v2/values.json
new file mode 100644
index 0000000..e71cefa
--- /dev/null
+++ b/src/src/app/build/intermediates/blame/res/debug/multi-v2/values.json
@@ -0,0 +1,174 @@
+{
+ "logs": [
+ {
+ "outputFile": "E:\\Note\\src\\app\\build\\intermediates\\incremental\\mergeDebugResources\\merged.dir\\values\\values.xml",
+ "map": [
+ {
+ "source": "E:\\Note\\src\\app\\src\\main\\res\\values\\colors.xml",
+ "from": {
+ "startLines": "18",
+ "startColumns": "4",
+ "startOffsets": "730",
+ "endColumns": "56",
+ "endOffsets": "782"
+ },
+ "to": {
+ "startLines": "83",
+ "startColumns": "4",
+ "startOffsets": "5347",
+ "endColumns": "56",
+ "endOffsets": "5399"
+ }
+ },
+ {
+ "source": "E:\\Note\\src\\app\\src\\main\\res\\values\\arrays.xml",
+ "from": {
+ "startLines": "19,26",
+ "startColumns": "4,4",
+ "startOffsets": "758,1073",
+ "endLines": "24,29",
+ "endColumns": "19,19",
+ "endOffsets": "1065,1191"
+ },
+ "to": {
+ "startLines": "2,8",
+ "startColumns": "4,4",
+ "startOffsets": "105,412",
+ "endLines": "7,11",
+ "endColumns": "19,19",
+ "endOffsets": "407,527"
+ }
+ },
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\88c548461109b0c917067cfea58751b3\\appcompat-1.0.0-alpha1\\res\\values\\values.xml",
+ "from": {
+ "startLines": "2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19,20,21,22,23,24,25,26,27,28,29,30,31,32,33,34,35,36,37,38,39,40,41,42,43,44,45,46,47,48,49,50,51,52,53,54,55,56,57,58,59,60,61,62,63,64,65,66,67,68,1233,1234,1235,1236,1237,1238,1239,1240,1241,1242,1243,1244,1245,1246,1247,1248,1249,1250,1251,1252,1253,1254,1255,1256,1257,1258,1259,1260,1261,1262,1263,1264,1265,1266,1267,1268,1269,1270,1271,1272,1273,1274,1275,1276,1277,1278,1279,1280,1281,1282,1283,1284,1285,1286,1287,1288,1289,1290,1291,1292,1293,1294,1295,1296,1297,1298,1299,1300,1301,1302,1303,1304,1305,1306,1307,1308,1309,1310,1311,1312,1313,1314,1315,1316,1317,1318,1319,1320,1321,1322,1323,1324,1325,1326,1327,1328,1329,1330,1331,1332,1333,1334,1335,1336,1337,1338,1339,1340,1341,1342,1343,1344,1345,1346,1347,1348,1349,1350,1351,1352,1353,1354,1355,1356,1357,1358,1359,1360,1361,1362,1363,1364,1365,1366,1367,1368,1369,1370,1371,1372,1373,1374,1375,1376,1377,1378,1379,1380,1381,1382,1383,1391,1392,1396,1400,1404,1409,1415,1422,1426,1430,1435,1439,1443,1447,1451,1455,1459,1465,1469,1475,1479,1485,1489,1494,1498,1501,1505,1511,1515,1521,1525,1531,1534,1538,1542,1546,1550,1554,1555,1556,1557,1560,1563,1566,1569,1573,1574,1575,1576,1577,1580,1582,1584,1586,1591,1592,1596,1602,1606,1607,1609,1620,1621,1625,1631,1635,1636,1637,1641,1668,1672,1673,1677,1705,1873,1899,2068,2094,2125,2133,2139,2153,2175,2180,2185,2195,2204,2213,2217,2224,2232,2239,2240,2249,2252,2255,2259,2263,2267,2270,2271,2275,2279,2289,2294,2301,2307,2308,2311,2315,2320,2322,2324,2327,2330,2332,2336,2339,2346,2349,2352,2356,2358,2362,2364,2366,2368,2372,2380,2388,2400,2406,2415,2418,2429,2432,2437,2438,2443,2501,2560,2561,2571,2580,2581,2583,2587,2590,2593,2596,2599,2602,2605,2608,2612,2615,2618,2621,2625,2628,2632,2636,2637,2638,2639,2640,2641,2642,2643,2644,2645,2646,2647,2648,2649,2650,2651,2652,2653,2654,2655,2656,2658,2660,2661,2662,2663,2664,2665,2666,2667,2669,2670,2672,2673,2675,2677,2678,2680,2681,2682,2683,2684,2685,2687,2688,2689,2690,2691,2692,2694,2696,2698,2699,2700,2701,2702,2703,2704,2705,2706,2707,2708,2709,2710,2712,2713,2714,2715,2716,2717,2719,2723,2727,2728,2729,2730,2731,2732,2733,2734,2736,2738,2740,2742,2744,2745,2746,2747,2749,2751,2753,2754,2755,2756,2757,2758,2759,2760,2761,2762,2763,2764,2767,2768,2769,2770,2772,2774,2775,2777,2778,2780,2782,2784,2785,2786,2787,2788,2789,2790,2791,2792,2793,2794,2795,2797,2798,2799,2800,2802,2803,2804,2805,2806,2808,2810,2812,2814,2815,2816,2817,2818,2819,2820,2821,2822,2823,2824,2825,2826,2827,69,152,155,158,161,175,186,196,226,253,262,299,680,692,718,736,772,778,784,807,948,968,974,978,984,1021,1033,1099,1114,1179,1198,1224",
+ "startColumns": "4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4",
+ "startOffsets": "105,160,205,254,295,350,409,471,552,613,688,764,841,919,1004,1086,1162,1238,1315,1393,1499,1605,1684,1764,1821,1879,1953,2028,2093,2159,2219,2280,2352,2425,2492,2560,2619,2678,2737,2796,2855,2909,2963,3016,3070,3124,3178,3232,3306,3385,3458,3532,3603,3675,3747,3820,3877,3935,4008,4082,4156,4231,4303,4376,4446,4517,4577,66677,66746,66815,66885,66959,67035,67099,67176,67252,67329,67394,67463,67540,67615,67684,67752,67829,67895,67956,68053,68118,68187,68286,68357,68416,68474,68531,68590,68654,68725,68797,68869,68941,69013,69080,69148,69216,69275,69338,69402,69492,69583,69643,69709,69776,69842,69912,69976,70029,70142,70200,70263,70328,70393,70468,70541,70613,70662,70723,70784,70845,70907,70971,71035,71099,71164,71227,71287,71348,71414,71473,71533,71595,71666,71726,71794,71880,71967,72057,72144,72232,72314,72397,72487,72578,72630,72688,72733,72799,72863,72920,72977,73031,73088,73136,73185,73236,73270,73317,73366,73412,73444,73508,73570,73630,73687,73761,73831,73909,73963,74033,74118,74166,74212,74283,74361,74439,74511,74585,74659,74733,74813,74886,74955,75027,75104,75165,75228,75294,75358,75429,75492,75557,75621,75682,75743,75795,75868,75942,76011,76086,76160,76234,76375,76445,76498,76576,76666,76754,76850,76940,77522,77611,77858,78139,78391,78676,79069,79546,79768,79990,80266,80493,80723,80953,81183,81413,81640,82059,82285,82710,82940,83368,83587,83870,84078,84209,84436,84862,85087,85514,85735,86160,86280,86556,86857,87181,87472,87786,87923,88054,88159,88401,88568,88772,88980,89251,89363,89475,89580,89697,89911,90057,90197,90283,90631,90719,90965,91383,91632,91714,91812,92429,92529,92781,93205,93460,93554,93643,93880,95932,96174,96276,96529,98713,109434,110950,121770,123298,125055,125681,126101,127162,128427,128683,128919,129466,129960,130565,130763,131343,131907,132282,132400,132938,133095,133291,133564,133820,133990,134131,134195,134477,134763,135439,135703,136041,136394,136488,136674,136980,137242,137367,137494,137733,137944,138063,138256,138433,138888,139069,139191,139450,139563,139750,139852,139959,140088,140363,140871,141367,142244,142538,143108,143257,143989,144161,144497,144589,144867,149211,153698,153760,154390,155004,155095,155208,155437,155597,155749,155920,156086,156255,156422,156585,156828,156998,157171,157342,157616,157815,158020,158350,158434,158530,158626,158724,158824,158926,159028,159130,159232,159334,159434,159530,159642,159771,159894,160025,160156,160254,160368,160462,160602,160736,160832,160944,161044,161160,161256,161368,161468,161608,161744,161908,162038,162196,162346,162487,162631,162766,162878,163028,163156,163284,163420,163552,163682,163812,163924,164064,164210,164354,164492,164558,164648,164724,164828,164918,165020,165128,165236,165336,165416,165508,165606,165716,165794,165900,165992,166096,166206,166328,166491,166648,166728,166828,166918,167028,167122,167228,167320,167420,167532,167646,167762,167878,167972,168086,168198,168300,168420,168542,168624,168728,168848,168974,169072,169166,169254,169366,169482,169604,169716,169891,170007,170093,170185,170297,170421,170488,170614,170682,170810,170954,171082,171151,171246,171361,171474,171573,171682,171793,171904,172005,172110,172210,172340,172431,172554,172648,172760,172846,172950,173046,173134,173252,173356,173460,173586,173674,173782,173882,173972,174082,174166,174268,174352,174406,174470,174576,174686,174770,4638,9782,9900,10015,10147,10862,11554,12071,13670,15203,15591,17898,37416,37974,39366,40399,42412,42674,43030,43860,50642,51776,52070,52293,52620,54670,55318,59169,59770,63579,64794,66203",
+ "endLines": "2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19,20,21,22,23,24,25,26,27,28,29,30,31,32,33,34,35,36,37,38,39,40,41,42,43,44,45,46,47,48,49,50,51,52,53,54,55,56,57,58,59,60,61,62,63,64,65,66,67,68,1233,1234,1235,1236,1237,1238,1239,1240,1241,1242,1243,1244,1245,1246,1247,1248,1249,1250,1251,1252,1253,1254,1255,1256,1257,1258,1259,1260,1261,1262,1263,1264,1265,1266,1267,1268,1269,1270,1271,1272,1273,1274,1275,1276,1277,1278,1279,1280,1281,1282,1283,1284,1285,1286,1287,1288,1289,1290,1291,1292,1293,1294,1295,1296,1297,1298,1299,1300,1301,1302,1303,1304,1305,1306,1307,1308,1309,1310,1311,1312,1313,1314,1315,1316,1317,1318,1319,1320,1321,1322,1323,1324,1325,1326,1327,1328,1329,1330,1331,1332,1333,1334,1335,1336,1337,1338,1339,1340,1341,1342,1343,1344,1345,1346,1347,1348,1349,1350,1351,1352,1353,1354,1355,1356,1357,1358,1359,1360,1361,1362,1363,1364,1365,1366,1367,1368,1369,1370,1371,1372,1373,1374,1375,1376,1377,1378,1379,1380,1381,1382,1390,1391,1395,1399,1403,1408,1414,1421,1425,1429,1434,1438,1442,1446,1450,1454,1458,1464,1468,1474,1478,1484,1488,1493,1497,1500,1504,1510,1514,1520,1524,1530,1533,1537,1541,1545,1549,1553,1554,1555,1556,1559,1562,1565,1568,1572,1573,1574,1575,1576,1579,1581,1583,1585,1590,1591,1595,1601,1605,1606,1608,1619,1620,1624,1630,1634,1635,1636,1640,1667,1671,1672,1676,1704,1872,1898,2067,2093,2124,2132,2138,2152,2174,2179,2184,2194,2203,2212,2216,2223,2231,2238,2239,2248,2251,2254,2258,2262,2266,2269,2270,2274,2278,2288,2293,2300,2306,2307,2310,2314,2319,2321,2323,2326,2329,2331,2335,2338,2345,2348,2351,2355,2357,2361,2363,2365,2367,2371,2379,2387,2399,2405,2414,2417,2428,2431,2436,2437,2442,2500,2559,2560,2570,2579,2580,2582,2586,2589,2592,2595,2598,2601,2604,2607,2611,2614,2617,2620,2624,2627,2631,2635,2636,2637,2638,2639,2640,2641,2642,2643,2644,2645,2646,2647,2648,2649,2650,2651,2652,2653,2654,2655,2657,2659,2660,2661,2662,2663,2664,2665,2666,2668,2669,2671,2672,2674,2676,2677,2679,2680,2681,2682,2683,2684,2686,2687,2688,2689,2690,2691,2693,2695,2697,2698,2699,2700,2701,2702,2703,2704,2705,2706,2707,2708,2709,2711,2712,2713,2714,2715,2716,2718,2722,2726,2727,2728,2729,2730,2731,2732,2733,2735,2737,2739,2741,2743,2744,2745,2746,2748,2750,2752,2753,2754,2755,2756,2757,2758,2759,2760,2761,2762,2763,2766,2767,2768,2769,2771,2773,2774,2776,2777,2779,2781,2783,2784,2785,2786,2787,2788,2789,2790,2791,2792,2793,2794,2796,2797,2798,2799,2801,2802,2803,2804,2805,2807,2809,2811,2813,2814,2815,2816,2817,2818,2819,2820,2821,2822,2823,2824,2825,2826,2827,151,154,157,160,174,185,195,225,252,261,298,679,684,717,735,771,777,783,806,947,967,973,977,983,1020,1032,1098,1113,1178,1197,1223,1232",
+ "endColumns": "54,44,48,40,54,58,61,80,60,74,75,76,77,84,81,75,75,76,77,105,105,78,79,56,57,73,74,64,65,59,60,71,72,66,67,58,58,58,58,58,53,53,52,53,53,53,53,73,78,72,73,70,71,71,72,56,57,72,73,73,74,71,72,69,70,59,60,68,68,69,73,75,63,76,75,76,64,68,76,74,68,67,76,65,60,96,64,68,98,70,58,57,56,58,63,70,71,71,71,71,66,67,67,58,62,63,89,90,59,65,66,65,69,63,52,112,57,62,64,64,74,72,71,48,60,60,60,61,63,63,63,64,62,59,60,65,58,59,61,70,59,67,85,86,89,86,87,81,82,89,90,51,57,44,65,63,56,56,53,56,47,48,50,33,46,48,45,31,63,61,59,56,73,69,77,53,69,84,47,45,70,77,77,71,73,73,73,79,72,68,71,76,60,62,65,63,70,62,64,63,60,60,51,72,73,68,74,73,73,140,69,52,77,89,87,95,89,12,88,12,12,12,12,12,12,12,12,12,12,12,12,12,12,12,12,12,12,12,12,12,12,12,12,12,12,12,12,12,12,12,12,12,12,12,12,136,130,104,12,12,12,12,12,111,111,104,116,12,12,12,12,12,87,12,12,12,81,12,12,99,12,12,12,93,88,12,12,12,101,12,12,12,12,12,12,12,12,12,12,12,12,12,12,12,12,12,12,12,12,117,12,12,12,12,12,12,12,63,12,12,12,12,12,12,93,12,12,12,12,12,12,12,12,12,12,12,12,12,12,12,12,12,12,12,12,12,12,12,12,12,12,12,12,12,91,12,12,12,61,12,12,90,12,12,12,12,12,12,12,12,12,12,12,12,12,12,12,12,12,83,95,95,97,99,101,101,101,101,101,99,95,111,128,122,130,130,97,113,93,12,12,95,111,99,115,95,111,99,12,135,12,129,12,12,140,12,134,111,149,127,127,12,131,129,129,111,139,12,12,12,65,89,75,103,89,101,107,107,99,79,91,97,12,77,105,91,103,109,12,12,12,79,99,89,109,93,105,91,12,12,12,12,12,93,113,111,12,12,12,81,103,119,125,97,93,87,111,115,121,111,12,115,85,91,12,12,66,12,67,12,12,12,68,94,114,112,98,108,110,110,100,104,99,12,90,122,93,12,85,103,95,87,12,12,12,12,87,107,99,89,109,83,101,83,53,63,105,109,83,119,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24",
+ "endOffsets": "155,200,249,290,345,404,466,547,608,683,759,836,914,999,1081,1157,1233,1310,1388,1494,1600,1679,1759,1816,1874,1948,2023,2088,2154,2214,2275,2347,2420,2487,2555,2614,2673,2732,2791,2850,2904,2958,3011,3065,3119,3173,3227,3301,3380,3453,3527,3598,3670,3742,3815,3872,3930,4003,4077,4151,4226,4298,4371,4441,4512,4572,4633,66741,66810,66880,66954,67030,67094,67171,67247,67324,67389,67458,67535,67610,67679,67747,67824,67890,67951,68048,68113,68182,68281,68352,68411,68469,68526,68585,68649,68720,68792,68864,68936,69008,69075,69143,69211,69270,69333,69397,69487,69578,69638,69704,69771,69837,69907,69971,70024,70137,70195,70258,70323,70388,70463,70536,70608,70657,70718,70779,70840,70902,70966,71030,71094,71159,71222,71282,71343,71409,71468,71528,71590,71661,71721,71789,71875,71962,72052,72139,72227,72309,72392,72482,72573,72625,72683,72728,72794,72858,72915,72972,73026,73083,73131,73180,73231,73265,73312,73361,73407,73439,73503,73565,73625,73682,73756,73826,73904,73958,74028,74113,74161,74207,74278,74356,74434,74506,74580,74654,74728,74808,74881,74950,75022,75099,75160,75223,75289,75353,75424,75487,75552,75616,75677,75738,75790,75863,75937,76006,76081,76155,76229,76370,76440,76493,76571,76661,76749,76845,76935,77517,77606,77853,78134,78386,78671,79064,79541,79763,79985,80261,80488,80718,80948,81178,81408,81635,82054,82280,82705,82935,83363,83582,83865,84073,84204,84431,84857,85082,85509,85730,86155,86275,86551,86852,87176,87467,87781,87918,88049,88154,88396,88563,88767,88975,89246,89358,89470,89575,89692,89906,90052,90192,90278,90626,90714,90960,91378,91627,91709,91807,92424,92524,92776,93200,93455,93549,93638,93875,95927,96169,96271,96524,98708,109429,110945,121765,123293,125050,125676,126096,127157,128422,128678,128914,129461,129955,130560,130758,131338,131902,132277,132395,132933,133090,133286,133559,133815,133985,134126,134190,134472,134758,135434,135698,136036,136389,136483,136669,136975,137237,137362,137489,137728,137939,138058,138251,138428,138883,139064,139186,139445,139558,139745,139847,139954,140083,140358,140866,141362,142239,142533,143103,143252,143984,144156,144492,144584,144862,149206,153693,153755,154385,154999,155090,155203,155432,155592,155744,155915,156081,156250,156417,156580,156823,156993,157166,157337,157611,157810,158015,158345,158429,158525,158621,158719,158819,158921,159023,159125,159227,159329,159429,159525,159637,159766,159889,160020,160151,160249,160363,160457,160597,160731,160827,160939,161039,161155,161251,161363,161463,161603,161739,161903,162033,162191,162341,162482,162626,162761,162873,163023,163151,163279,163415,163547,163677,163807,163919,164059,164205,164349,164487,164553,164643,164719,164823,164913,165015,165123,165231,165331,165411,165503,165601,165711,165789,165895,165987,166091,166201,166323,166486,166643,166723,166823,166913,167023,167117,167223,167315,167415,167527,167641,167757,167873,167967,168081,168193,168295,168415,168537,168619,168723,168843,168969,169067,169161,169249,169361,169477,169599,169711,169886,170002,170088,170180,170292,170416,170483,170609,170677,170805,170949,171077,171146,171241,171356,171469,171568,171677,171788,171899,172000,172105,172205,172335,172426,172549,172643,172755,172841,172945,173041,173129,173247,173351,173455,173581,173669,173777,173877,173967,174077,174161,174263,174347,174401,174465,174571,174681,174765,174885,9777,9895,10010,10142,10857,11549,12066,13665,15198,15586,17893,37411,37671,39361,40394,42407,42669,43025,43855,50637,51771,52065,52288,52615,54665,55313,59164,59765,63574,64789,66198,66672"
+ },
+ "to": {
+ "startLines": "13,14,15,16,17,18,19,20,21,22,23,24,25,26,27,28,29,30,31,32,33,34,35,36,37,38,39,40,41,42,43,44,45,46,47,48,49,50,51,52,53,54,55,56,57,58,59,63,64,65,66,67,68,69,70,71,72,73,74,75,76,77,78,79,80,81,82,84,85,86,87,88,89,90,91,92,93,94,95,96,97,98,99,100,101,102,103,104,105,106,107,108,109,110,111,112,113,114,115,116,117,118,119,120,121,122,123,124,125,126,127,128,129,130,131,132,133,134,135,136,137,138,139,140,141,142,143,144,145,146,147,148,149,150,151,152,153,154,155,156,157,158,166,167,168,169,170,171,172,173,174,199,200,201,202,203,204,205,206,209,210,211,212,213,216,217,218,225,226,227,228,229,236,237,238,239,240,241,242,243,244,245,246,247,248,249,250,251,252,253,254,255,256,257,258,259,260,261,262,263,264,265,266,267,268,269,270,271,272,273,274,371,388,389,390,391,392,393,401,402,406,410,414,419,425,432,436,440,445,449,453,457,461,465,469,475,479,485,489,495,499,504,508,511,515,521,525,531,535,541,544,548,552,556,560,564,565,566,567,570,573,576,579,583,584,585,586,587,590,592,594,596,601,602,606,612,616,617,619,630,631,635,641,645,646,647,651,678,682,683,687,715,883,909,1078,1104,1135,1143,1149,1163,1185,1190,1195,1205,1214,1223,1227,1234,1242,1249,1250,1259,1262,1265,1269,1273,1277,1280,1281,1285,1289,1299,1304,1311,1317,1318,1321,1325,1330,1332,1334,1337,1340,1342,1346,1349,1356,1359,1362,1366,1368,1372,1374,1376,1378,1382,1390,1398,1410,1416,1425,1428,1439,1442,1447,1448,1467,1525,1584,1585,1595,1604,1605,1607,1611,1614,1617,1620,1623,1626,1629,1632,1636,1639,1642,1645,1649,1652,1656,1660,1661,1662,1663,1664,1665,1666,1667,1668,1669,1670,1671,1672,1673,1674,1675,1676,1677,1678,1679,1680,1682,1684,1685,1686,1687,1688,1689,1690,1691,1693,1694,1696,1697,1699,1701,1702,1704,1705,1706,1707,1708,1709,1711,1712,1713,1714,1715,1732,1734,1736,1766,1767,1768,1769,1770,1771,1772,1773,1774,1775,1776,1777,1778,1780,1781,1782,1783,1784,1785,1787,1791,1795,1796,1797,1798,1799,1800,1801,1802,1804,1806,1808,1810,1812,1813,1814,1815,1817,1819,1821,1822,1823,1824,1825,1826,1827,1828,1829,1830,1831,1832,1835,1836,1837,1838,1840,1842,1843,1845,1846,1848,1850,1852,1853,1854,1855,1856,1857,1858,1859,1860,1861,1862,1863,1865,1866,1867,1868,1870,1871,1872,1873,1874,1876,1878,1880,1882,1883,1884,1885,1886,1887,1888,1889,1890,1891,1892,1893,1894,1895,1901,1984,1987,1990,1993,2007,2018,2028,2058,2085,2094,2131,2512,2518,2643,2780,2816,2822,2828,2851,2992,3012,3018,3022,3028,3065,3077,3143,3158,3223,3242,3268",
+ "startColumns": "4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4",
+ "startOffsets": "593,648,693,742,783,838,897,959,1040,1101,1176,1252,1329,1407,1492,1574,1650,1726,1803,1881,1987,2093,2172,2252,2309,2367,2441,2516,2581,2647,2707,2768,2840,2913,2980,3048,3107,3166,3225,3284,3343,3397,3451,3504,3558,3612,3666,3941,4015,4094,4167,4241,4312,4384,4456,4529,4586,4644,4717,4791,4865,4940,5012,5085,5155,5226,5286,5404,5473,5542,5612,5686,5762,5826,5903,5979,6056,6121,6190,6267,6342,6411,6479,6556,6622,6683,6780,6845,6914,7013,7084,7143,7201,7258,7317,7381,7452,7524,7596,7668,7740,7807,7875,7943,8002,8065,8129,8219,8310,8370,8436,8503,8569,8639,8703,8756,8869,8927,8990,9055,9120,9195,9268,9340,9389,9450,9511,9572,9634,9698,9762,9826,9891,9954,10014,10075,10141,10200,10260,10322,10393,10453,11009,11095,11182,11272,11359,11447,11529,11612,11702,13245,13297,13355,13400,13466,13530,13587,13644,13846,13903,13951,14000,14051,14155,14202,14251,14569,14601,14665,14727,14787,15307,15381,15451,15529,15583,15653,15738,15786,15832,15903,15981,16059,16131,16205,16279,16353,16433,16506,16575,16647,16724,16785,16848,16914,16978,17049,17112,17177,17241,17302,17363,17415,17488,17562,17631,17706,17780,17854,17995,24560,25758,25836,25926,26014,26110,26200,26782,26871,27118,27399,27651,27936,28329,28806,29028,29250,29526,29753,29983,30213,30443,30673,30900,31319,31545,31970,32200,32628,32847,33130,33338,33469,33696,34122,34347,34774,34995,35420,35540,35816,36117,36441,36732,37046,37183,37314,37419,37661,37828,38032,38240,38511,38623,38735,38840,38957,39171,39317,39457,39543,39891,39979,40225,40643,40892,40974,41072,41689,41789,42041,42465,42720,42814,42903,43140,45192,45434,45536,45789,47973,58694,60210,71030,72558,74315,74941,75361,76422,77687,77943,78179,78726,79220,79825,80023,80603,81167,81542,81660,82198,82355,82551,82824,83080,83250,83391,83455,83737,84023,84699,84963,85301,85654,85748,85934,86240,86502,86627,86754,86993,87204,87323,87516,87693,88148,88329,88451,88710,88823,89010,89112,89219,89348,89623,90131,90627,91504,91798,92368,92517,93249,93421,93757,93849,94866,99210,103697,103759,104389,105003,105094,105207,105436,105596,105748,105919,106085,106254,106421,106584,106827,106997,107170,107341,107615,107814,108019,108349,108433,108529,108625,108723,108823,108925,109027,109129,109231,109333,109433,109529,109641,109770,109893,110024,110155,110253,110367,110461,110601,110735,110831,110943,111043,111159,111255,111367,111467,111607,111743,111907,112037,112195,112345,112486,112630,112765,112877,113027,113155,113283,113419,113551,113681,113811,113923,115203,115349,115493,116977,117043,117133,117209,117313,117403,117505,117613,117721,117821,117901,117993,118091,118201,118279,118385,118477,118581,118691,118813,118976,119133,119213,119313,119403,119513,119607,119713,119805,119905,120017,120131,120247,120363,120457,120571,120683,120785,120905,121027,121109,121213,121333,121459,121557,121651,121739,121851,121967,122089,122201,122376,122492,122578,122670,122782,122906,122973,123099,123167,123295,123439,123567,123636,123731,123846,123959,124058,124167,124278,124389,124490,124595,124695,124825,124916,125039,125133,125245,125331,125435,125531,125619,125737,125841,125945,126071,126159,126267,126367,126457,126567,126651,126753,126837,126891,126955,127061,127171,127255,127659,132803,132921,133036,133168,133883,134575,135092,136691,138224,138612,140919,160437,160858,168069,176210,178223,178485,178841,179671,186453,187587,187881,188104,188431,190481,191129,194980,195581,199390,200605,202014",
+ "endLines": "13,14,15,16,17,18,19,20,21,22,23,24,25,26,27,28,29,30,31,32,33,34,35,36,37,38,39,40,41,42,43,44,45,46,47,48,49,50,51,52,53,54,55,56,57,58,59,63,64,65,66,67,68,69,70,71,72,73,74,75,76,77,78,79,80,81,82,84,85,86,87,88,89,90,91,92,93,94,95,96,97,98,99,100,101,102,103,104,105,106,107,108,109,110,111,112,113,114,115,116,117,118,119,120,121,122,123,124,125,126,127,128,129,130,131,132,133,134,135,136,137,138,139,140,141,142,143,144,145,146,147,148,149,150,151,152,153,154,155,156,157,158,166,167,168,169,170,171,172,173,174,199,200,201,202,203,204,205,206,209,210,211,212,213,216,217,218,225,226,227,228,229,236,237,238,239,240,241,242,243,244,245,246,247,248,249,250,251,252,253,254,255,256,257,258,259,260,261,262,263,264,265,266,267,268,269,270,271,272,273,274,371,388,389,390,391,392,400,401,405,409,413,418,424,431,435,439,444,448,452,456,460,464,468,474,478,484,488,494,498,503,507,510,514,520,524,530,534,540,543,547,551,555,559,563,564,565,566,569,572,575,578,582,583,584,585,586,589,591,593,595,600,601,605,611,615,616,618,629,630,634,640,644,645,646,650,677,681,682,686,714,882,908,1077,1103,1134,1142,1148,1162,1184,1189,1194,1204,1213,1222,1226,1233,1241,1248,1249,1258,1261,1264,1268,1272,1276,1279,1280,1284,1288,1298,1303,1310,1316,1317,1320,1324,1329,1331,1333,1336,1339,1341,1345,1348,1355,1358,1361,1365,1367,1371,1373,1375,1377,1381,1389,1397,1409,1415,1424,1427,1438,1441,1446,1447,1452,1524,1583,1584,1594,1603,1604,1606,1610,1613,1616,1619,1622,1625,1628,1631,1635,1638,1641,1644,1648,1651,1655,1659,1660,1661,1662,1663,1664,1665,1666,1667,1668,1669,1670,1671,1672,1673,1674,1675,1676,1677,1678,1679,1681,1683,1684,1685,1686,1687,1688,1689,1690,1692,1693,1695,1696,1698,1700,1701,1703,1704,1705,1706,1707,1708,1710,1711,1712,1713,1714,1715,1733,1735,1737,1766,1767,1768,1769,1770,1771,1772,1773,1774,1775,1776,1777,1779,1780,1781,1782,1783,1784,1786,1790,1794,1795,1796,1797,1798,1799,1800,1801,1803,1805,1807,1809,1811,1812,1813,1814,1816,1818,1820,1821,1822,1823,1824,1825,1826,1827,1828,1829,1830,1831,1834,1835,1836,1837,1839,1841,1842,1844,1845,1847,1849,1851,1852,1853,1854,1855,1856,1857,1858,1859,1860,1861,1862,1864,1865,1866,1867,1869,1870,1871,1872,1873,1875,1877,1879,1881,1882,1883,1884,1885,1886,1887,1888,1889,1890,1891,1892,1893,1894,1895,1983,1986,1989,1992,2006,2017,2027,2057,2084,2093,2130,2511,2516,2543,2660,2815,2821,2827,2850,2991,3011,3017,3021,3027,3064,3076,3142,3157,3222,3241,3267,3276",
+ "endColumns": "54,44,48,40,54,58,61,80,60,74,75,76,77,84,81,75,75,76,77,105,105,78,79,56,57,73,74,64,65,59,60,71,72,66,67,58,58,58,58,58,53,53,52,53,53,53,53,73,78,72,73,70,71,71,72,56,57,72,73,73,74,71,72,69,70,59,60,68,68,69,73,75,63,76,75,76,64,68,76,74,68,67,76,65,60,96,64,68,98,70,58,57,56,58,63,70,71,71,71,71,66,67,67,58,62,63,89,90,59,65,66,65,69,63,52,112,57,62,64,64,74,72,71,48,60,60,60,61,63,63,63,64,62,59,60,65,58,59,61,70,59,67,85,86,89,86,87,81,82,89,90,51,57,44,65,63,56,56,53,56,47,48,50,33,46,48,45,31,63,61,59,56,73,69,77,53,69,84,47,45,70,77,77,71,73,73,73,79,72,68,71,76,60,62,65,63,70,62,64,63,60,60,51,72,73,68,74,73,73,140,69,52,77,89,87,95,89,12,88,12,12,12,12,12,12,12,12,12,12,12,12,12,12,12,12,12,12,12,12,12,12,12,12,12,12,12,12,12,12,12,12,12,12,12,12,136,130,104,12,12,12,12,12,111,111,104,116,12,12,12,12,12,87,12,12,12,81,12,12,99,12,12,12,93,88,12,12,12,101,12,12,12,12,12,12,12,12,12,12,12,12,12,12,12,12,12,12,12,12,117,12,12,12,12,12,12,12,63,12,12,12,12,12,12,93,12,12,12,12,12,12,12,12,12,12,12,12,12,12,12,12,12,12,12,12,12,12,12,12,12,12,12,12,12,91,12,12,12,61,12,12,90,12,12,12,12,12,12,12,12,12,12,12,12,12,12,12,12,12,83,95,95,97,99,101,101,101,101,101,99,95,111,128,122,130,130,97,113,93,12,12,95,111,99,115,95,111,99,12,135,12,129,12,12,140,12,134,111,149,127,127,12,131,129,129,111,139,12,12,12,65,89,75,103,89,101,107,107,99,79,91,97,12,77,105,91,103,109,12,12,12,79,99,89,109,93,105,91,12,12,12,12,12,93,113,111,12,12,12,81,103,119,125,97,93,87,111,115,121,111,12,115,85,91,12,12,66,12,67,12,12,12,68,94,114,112,98,108,110,110,100,104,99,12,90,122,93,12,85,103,95,87,12,12,12,12,87,107,99,89,109,83,101,83,53,63,105,109,83,119,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24",
+ "endOffsets": "643,688,737,778,833,892,954,1035,1096,1171,1247,1324,1402,1487,1569,1645,1721,1798,1876,1982,2088,2167,2247,2304,2362,2436,2511,2576,2642,2702,2763,2835,2908,2975,3043,3102,3161,3220,3279,3338,3392,3446,3499,3553,3607,3661,3715,4010,4089,4162,4236,4307,4379,4451,4524,4581,4639,4712,4786,4860,4935,5007,5080,5150,5221,5281,5342,5468,5537,5607,5681,5757,5821,5898,5974,6051,6116,6185,6262,6337,6406,6474,6551,6617,6678,6775,6840,6909,7008,7079,7138,7196,7253,7312,7376,7447,7519,7591,7663,7735,7802,7870,7938,7997,8060,8124,8214,8305,8365,8431,8498,8564,8634,8698,8751,8864,8922,8985,9050,9115,9190,9263,9335,9384,9445,9506,9567,9629,9693,9757,9821,9886,9949,10009,10070,10136,10195,10255,10317,10388,10448,10516,11090,11177,11267,11354,11442,11524,11607,11697,11788,13292,13350,13395,13461,13525,13582,13639,13693,13898,13946,13995,14046,14080,14197,14246,14292,14596,14660,14722,14782,14839,15376,15446,15524,15578,15648,15733,15781,15827,15898,15976,16054,16126,16200,16274,16348,16428,16501,16570,16642,16719,16780,16843,16909,16973,17044,17107,17172,17236,17297,17358,17410,17483,17557,17626,17701,17775,17849,17990,18060,24608,25831,25921,26009,26105,26195,26777,26866,27113,27394,27646,27931,28324,28801,29023,29245,29521,29748,29978,30208,30438,30668,30895,31314,31540,31965,32195,32623,32842,33125,33333,33464,33691,34117,34342,34769,34990,35415,35535,35811,36112,36436,36727,37041,37178,37309,37414,37656,37823,38027,38235,38506,38618,38730,38835,38952,39166,39312,39452,39538,39886,39974,40220,40638,40887,40969,41067,41684,41784,42036,42460,42715,42809,42898,43135,45187,45429,45531,45784,47968,58689,60205,71025,72553,74310,74936,75356,76417,77682,77938,78174,78721,79215,79820,80018,80598,81162,81537,81655,82193,82350,82546,82819,83075,83245,83386,83450,83732,84018,84694,84958,85296,85649,85743,85929,86235,86497,86622,86749,86988,87199,87318,87511,87688,88143,88324,88446,88705,88818,89005,89107,89214,89343,89618,90126,90622,91499,91793,92363,92512,93244,93416,93752,93844,94122,99205,103692,103754,104384,104998,105089,105202,105431,105591,105743,105914,106080,106249,106416,106579,106822,106992,107165,107336,107610,107809,108014,108344,108428,108524,108620,108718,108818,108920,109022,109124,109226,109328,109428,109524,109636,109765,109888,110019,110150,110248,110362,110456,110596,110730,110826,110938,111038,111154,111250,111362,111462,111602,111738,111902,112032,112190,112340,112481,112625,112760,112872,113022,113150,113278,113414,113546,113676,113806,113918,114058,115344,115488,115626,117038,117128,117204,117308,117398,117500,117608,117716,117816,117896,117988,118086,118196,118274,118380,118472,118576,118686,118808,118971,119128,119208,119308,119398,119508,119602,119708,119800,119900,120012,120126,120242,120358,120452,120566,120678,120780,120900,121022,121104,121208,121328,121454,121552,121646,121734,121846,121962,122084,122196,122371,122487,122573,122665,122777,122901,122968,123094,123162,123290,123434,123562,123631,123726,123841,123954,124053,124162,124273,124384,124485,124590,124690,124820,124911,125034,125128,125240,125326,125430,125526,125614,125732,125836,125940,126066,126154,126262,126362,126452,126562,126646,126748,126832,126886,126950,127056,127166,127250,127370,132798,132916,133031,133163,133878,134570,135087,136686,138219,138607,140914,160432,160692,162245,169097,178218,178480,178836,179666,186448,187582,187876,188099,188426,190476,191124,194975,195576,199385,200600,202009,202483"
+ }
+ },
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\702974eead929cb167f132efe0eabb04\\media-1.0.0\\res\\values\\values.xml",
+ "from": {
+ "startLines": "2,5,6,7,8,10,11,12,13,14",
+ "startColumns": "4,4,4,4,4,4,4,4,4,4",
+ "startOffsets": "55,288,341,394,447,560,626,748,809,875",
+ "endColumns": "88,52,52,52,52,65,121,60,65,66",
+ "endOffsets": "139,336,389,442,495,621,743,804,870,937"
+ },
+ "to": {
+ "startLines": "62,190,191,192,193,1721,1723,1724,1729,1731",
+ "startColumns": "4,4,4,4,4,4,4,4,4,4",
+ "startOffsets": "3852,12771,12824,12877,12930,114381,114557,114679,114941,115136",
+ "endColumns": "88,52,52,52,52,65,121,60,65,66",
+ "endOffsets": "3936,12819,12872,12925,12978,114442,114674,114735,115002,115198"
+ }
+ },
+ {
+ "source": "E:\\Note\\src\\app\\src\\main\\res\\values\\styles.xml",
+ "from": {
+ "startLines": "50,55,64,60,22,26,30,35,40,18,45",
+ "startColumns": "4,4,4,4,4,4,4,4,4,4,4",
+ "startOffsets": "2112,2322,2704,2539,917,1104,1293,1484,1693,730,1905",
+ "endLines": "53,58,66,62,25,29,33,38,43,21,48",
+ "endColumns": "12,12,12,12,12,12,12,12,12,12,12",
+ "endOffsets": "2314,2531,2865,2696,1098,1287,1476,1685,1897,911,2104"
+ },
+ "to": {
+ "startLines": "1453,1457,1461,1464,1738,1742,1746,1750,1754,1758,1762",
+ "startColumns": "4,4,4,4,4,4,4,4,4,4,4",
+ "startOffsets": "94127,94331,94542,94706,115631,115814,115999,116184,116387,116593,116776",
+ "endLines": "1456,1460,1463,1466,1741,1745,1749,1753,1757,1761,1765",
+ "endColumns": "12,12,12,12,12,12,12,12,12,12,12",
+ "endOffsets": "94326,94537,94701,94861,115809,115994,116179,116382,116588,116771,116972"
+ }
+ },
+ {
+ "source": "E:\\Note\\src\\app\\src\\main\\res\\values\\dimens.xml",
+ "from": {
+ "startLines": "19,20,21,22,18",
+ "startColumns": "4,4,4,4,4",
+ "startOffsets": "783,836,890,944,730",
+ "endColumns": "51,52,52,51,51",
+ "endOffsets": "830,884,938,991,777"
+ },
+ "to": {
+ "startLines": "194,195,196,197,198",
+ "startColumns": "4,4,4,4,4",
+ "startOffsets": "12983,13035,13088,13141,13193",
+ "endColumns": "51,52,52,51,51",
+ "endOffsets": "13030,13083,13136,13188,13240"
+ }
+ },
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\df8a19ef163eaa8f3d3c8f24458897fd\\coordinatorlayout-1.0.0\\res\\values\\values.xml",
+ "from": {
+ "startLines": "2,102,3,13",
+ "startColumns": "4,4,4,4",
+ "startOffsets": "55,5935,116,724",
+ "endLines": "2,104,12,101",
+ "endColumns": "60,12,24,24",
+ "endOffsets": "111,6075,719,5930"
+ },
+ "to": {
+ "startLines": "12,1898,2544,2554",
+ "startColumns": "4,4,4,4",
+ "startOffsets": "532,127514,162250,162858",
+ "endLines": "12,1900,2553,2642",
+ "endColumns": "60,12,24,24",
+ "endOffsets": "588,127654,162853,168064"
+ }
+ },
+ {
+ "source": "C:\\Users\\彭\\.gradle\\caches\\transforms-2\\files-2.1\\6d11613c3b6a00a9ea456b5609ec43f7\\core-1.0.0\\res\\values\\values.xml",
+ "from": {
+ "startLines": "2,3,132,133,134,135,136,137,138,139,140,141,142,143,144,145,146,147,148,149,150,151,152,153,154,155,156,157,158,159,160,161,162,163,164,165,166,167,171,172,176,177,178,13,56,88,125",
+ "startColumns": "4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4",
+ "startOffsets": "55,124,7725,7795,7863,7935,8005,8066,8140,8213,8274,8335,8397,8461,8523,8584,8652,8752,8812,8878,8951,9020,9077,9129,9191,9263,9339,9374,9409,9459,9520,9577,9611,9646,9681,9751,9822,9939,10140,10250,10451,10580,10652,617,3523,5588,7348",
+ "endLines": "2,3,132,133,134,135,136,137,138,139,140,141,142,143,144,145,146,147,148,149,150,151,152,153,154,155,156,157,158,159,160,161,162,163,164,165,166,170,171,175,176,177,178,55,87,124,131",
+ "endColumns": "68,62,69,67,71,69,60,73,72,60,60,61,63,61,60,67,99,59,65,72,68,56,51,61,71,75,34,34,49,60,56,33,34,34,69,70,116,12,109,12,128,71,66,24,24,24,24",
+ "endOffsets": "119,182,7790,7858,7930,8000,8061,8135,8208,8269,8330,8392,8456,8518,8579,8647,8747,8807,8873,8946,9015,9072,9124,9186,9258,9334,9369,9404,9454,9515,9572,9606,9641,9676,9746,9817,9934,10135,10245,10446,10575,10647,10714,3518,5583,7343,7720"
+ },
+ "to": {
+ "startLines": "60,61,159,160,161,162,163,164,165,175,176,177,178,179,180,181,182,183,184,185,186,187,188,189,207,208,214,215,219,220,221,222,223,224,230,375,1716,1717,1722,1725,1730,1896,1897,2661,2704,2736,2773",
+ "startColumns": "4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4",
+ "startOffsets": "3720,3789,10521,10591,10659,10731,10801,10862,10936,11793,11854,11915,11977,12041,12103,12164,12232,12332,12392,12458,12531,12600,12657,12709,13698,13770,14085,14120,14297,14347,14408,14465,14499,14534,14844,24804,114063,114180,114447,114740,115007,127375,127447,169102,172008,174073,175833",
+ "endLines": "60,61,159,160,161,162,163,164,165,175,176,177,178,179,180,181,182,183,184,185,186,187,188,189,207,208,214,215,219,220,221,222,223,224,230,375,1716,1720,1722,1728,1730,1896,1897,2703,2735,2772,2779",
+ "endColumns": "68,62,69,67,71,69,60,73,72,60,60,61,63,61,60,67,99,59,65,72,68,56,51,61,71,75,34,34,49,60,56,33,34,34,69,70,116,12,109,12,128,71,66,24,24,24,24",
+ "endOffsets": "3784,3847,10586,10654,10726,10796,10857,10931,11004,11849,11910,11972,12036,12098,12159,12227,12327,12387,12453,12526,12595,12652,12704,12766,13765,13841,14115,14150,14342,14403,14460,14494,14529,14564,14909,24870,114175,114376,114552,114936,115131,127442,127509,172003,174068,175828,176205"
+ }
+ },
+ {
+ "source": "E:\\Note\\src\\app\\src\\main\\res\\values\\strings.xml",
+ "from": {
+ "startLines": "138,82,85,84,83,29,30,31,128,129,23,137,136,27,36,22,25,91,92,90,89,88,104,103,102,94,49,48,74,39,40,95,51,86,130,81,21,19,77,20,52,58,63,53,73,72,71,67,66,64,65,68,69,59,80,70,78,57,62,61,60,76,56,75,54,55,79,38,44,46,43,45,42,41,35,34,111,110,114,126,119,118,120,121,123,122,112,113,117,115,116,109,124,125,135,133,132,134,26,37,93,101,106,105,107,24,100,99,98,97,32,33",
+ "startColumns": "4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4",
+ "startOffsets": "8684,4518,4782,4685,4615,1394,1438,1491,8172,8222,1121,8625,8573,1321,1856,1054,1223,5242,5337,5170,5085,5001,6216,6132,6029,5515,2591,2539,4009,2063,2117,5577,2686,4866,8286,4446,987,846,4197,908,2746,3067,3373,2805,3937,3875,3817,3591,3538,3433,3487,3642,3693,3115,4379,3754,4247,3019,3317,3228,3169,4134,2968,4088,2863,2907,4311,2007,2332,2442,2284,2388,2227,2178,1800,1746,6679,6611,6923,8073,7292,7210,7367,7457,7701,7621,6764,6840,7150,6988,7069,6555,7846,7969,8531,8402,8344,8456,1268,1941,5446,5942,6353,6283,6434,1172,5882,5826,5763,5702,1544,1655",
+ "endLines": "142,82,85,84,83,29,30,31,128,129,23,137,136,27,36,22,25,91,92,90,89,88,104,103,102,94,49,48,74,39,40,95,51,86,130,81,21,19,77,20,52,58,63,53,73,72,71,67,66,64,65,68,69,59,80,70,78,57,62,61,60,76,56,75,54,55,79,38,44,46,43,45,42,41,35,34,111,110,114,126,119,118,120,121,123,122,112,113,117,115,116,109,124,125,135,133,132,134,26,37,93,101,106,105,107,24,100,99,98,97,32,33",
+ "endColumns": "14,95,82,95,68,42,51,51,48,62,49,57,50,69,83,65,43,93,107,70,83,82,65,82,101,60,61,50,77,52,59,104,58,101,54,70,65,60,48,77,57,46,58,56,70,60,56,49,51,52,49,49,59,52,65,61,62,46,54,87,57,61,49,44,42,59,66,54,54,52,46,52,55,47,54,52,83,66,63,95,73,80,88,162,143,78,74,81,58,79,79,54,121,102,40,52,56,73,51,64,67,85,79,68,93,49,58,54,61,59,109,89",
+ "endOffsets": "9092,4609,4860,4776,4679,1432,1485,1538,8216,8280,1166,8678,8619,1386,1935,1115,1262,5331,5440,5236,5164,5079,6277,6210,6126,5571,2648,2585,4082,2111,2172,5677,2740,4963,8336,4512,1048,902,4241,981,2799,3109,3427,2857,4003,3931,3869,3636,3585,3481,3532,3687,3748,3163,4440,3811,4305,3061,3367,3311,3222,4191,3013,4128,2901,2962,4373,2057,2382,2490,2326,2436,2278,2221,1850,1794,6758,6673,6982,8164,7361,7286,7451,7615,7840,7695,6834,6917,7204,7063,7144,6605,7963,8067,8567,8450,8396,8525,1315,2001,5509,6023,6428,6347,6523,1217,5936,5876,5820,5757,1649,1740"
+ },
+ "to": {
+ "startLines": "231,275,276,277,278,279,280,281,282,283,284,285,286,287,288,289,290,291,292,293,294,295,296,297,298,299,300,301,302,303,304,305,306,307,308,309,310,311,312,313,314,315,316,317,318,319,320,321,322,323,324,325,326,327,328,329,330,331,332,333,334,335,336,337,338,339,340,341,342,343,344,345,346,347,348,349,350,351,352,353,354,355,356,357,358,359,360,361,362,363,364,365,366,367,368,369,370,372,373,374,376,377,378,379,380,381,382,383,384,385,386,387",
+ "startColumns": "4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4",
+ "startOffsets": "14914,18065,18161,18244,18340,18409,18452,18504,18556,18605,18668,18718,18776,18827,18897,18981,19047,19091,19185,19293,19364,19448,19531,19597,19680,19782,19843,19905,19956,20034,20087,20147,20252,20311,20413,20468,20539,20605,20666,20715,20793,20851,20898,20957,21014,21085,21146,21203,21253,21305,21358,21408,21458,21518,21571,21637,21699,21762,21809,21864,21952,22010,22072,22122,22167,22210,22270,22337,22392,22447,22500,22547,22600,22656,22704,22759,22812,22896,22963,23027,23123,23197,23278,23367,23530,23674,23753,23828,23910,23969,24049,24129,24184,24306,24409,24450,24503,24613,24687,24739,24875,24943,25029,25109,25178,25272,25322,25381,25436,25498,25558,25668",
+ "endLines": "235,275,276,277,278,279,280,281,282,283,284,285,286,287,288,289,290,291,292,293,294,295,296,297,298,299,300,301,302,303,304,305,306,307,308,309,310,311,312,313,314,315,316,317,318,319,320,321,322,323,324,325,326,327,328,329,330,331,332,333,334,335,336,337,338,339,340,341,342,343,344,345,346,347,348,349,350,351,352,353,354,355,356,357,358,359,360,361,362,363,364,365,366,367,368,369,370,372,373,374,376,377,378,379,380,381,382,383,384,385,386,387",
+ "endColumns": "14,95,82,95,68,42,51,51,48,62,49,57,50,69,83,65,43,93,107,70,83,82,65,82,101,60,61,50,77,52,59,104,58,101,54,70,65,60,48,77,57,46,58,56,70,60,56,49,51,52,49,49,59,52,65,61,62,46,54,87,57,61,49,44,42,59,66,54,54,52,46,52,55,47,54,52,83,66,63,95,73,80,88,162,143,78,74,81,58,79,79,54,121,102,40,52,56,73,51,64,67,85,79,68,93,49,58,54,61,59,109,89",
+ "endOffsets": "15302,18156,18239,18335,18404,18447,18499,18551,18600,18663,18713,18771,18822,18892,18976,19042,19086,19180,19288,19359,19443,19526,19592,19675,19777,19838,19900,19951,20029,20082,20142,20247,20306,20408,20463,20534,20600,20661,20710,20788,20846,20893,20952,21009,21080,21141,21198,21248,21300,21353,21403,21453,21513,21566,21632,21694,21757,21804,21859,21947,22005,22067,22117,22162,22205,22265,22332,22387,22442,22495,22542,22595,22651,22699,22754,22807,22891,22958,23022,23118,23192,23273,23362,23525,23669,23748,23823,23905,23964,24044,24124,24179,24301,24404,24445,24498,24555,24682,24734,24799,24938,25024,25104,25173,25267,25317,25376,25431,25493,25553,25663,25753"
+ }
+ }
+ ]
+ }
+ ]
+}
\ No newline at end of file
diff --git a/src/src/app/build/intermediates/blame/res/debug/single/debug.json b/src/src/app/build/intermediates/blame/res/debug/single/debug.json
new file mode 100644
index 0000000..b331f25
--- /dev/null
+++ b/src/src/app/build/intermediates/blame/res/debug/single/debug.json
@@ -0,0 +1,442 @@
+[
+ {
+ "merged": "E:\\Note\\src\\app\\build\\intermediates\\res\\merged\\debug\\layout_note_edit.xml.flat",
+ "source": "E:\\Note\\src\\app\\src\\main\\res\\layout\\note_edit.xml"
+ },
+ {
+ "merged": "E:\\Note\\src\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_widget_4x_yellow.png.flat",
+ "source": "E:\\Note\\src\\app\\src\\main\\res\\drawable-hdpi\\widget_4x_yellow.png"
+ },
+ {
+ "merged": "E:\\Note\\src\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_icon_app.png.flat",
+ "source": "E:\\Note\\src\\app\\src\\main\\res\\drawable-hdpi\\icon_app.png"
+ },
+ {
+ "merged": "E:\\Note\\src\\app\\build\\intermediates\\res\\merged\\debug\\raw_passwd.txt.flat",
+ "source": "E:\\Note\\src\\app\\src\\main\\res\\raw\\passwd.txt"
+ },
+ {
+ "merged": "E:\\Note\\src\\app\\build\\intermediates\\res\\merged\\debug\\raw-zh-rCN_introduction.flat",
+ "source": "E:\\Note\\src\\app\\src\\main\\res\\raw-zh-rCN\\introduction"
+ },
+ {
+ "merged": "E:\\Note\\src\\app\\build\\intermediates\\res\\merged\\debug\\color_secondary_text_dark.xml.flat",
+ "source": "E:\\Note\\src\\app\\src\\main\\res\\color\\secondary_text_dark.xml"
+ },
+ {
+ "merged": "E:\\Note\\src\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_list_footer_bg.9.png.flat",
+ "source": "E:\\Note\\src\\app\\src\\main\\res\\drawable-hdpi\\list_footer_bg.9.png"
+ },
+ {
+ "merged": "E:\\Note\\src\\app\\build\\intermediates\\res\\merged\\debug\\menu_note_list_options.xml.flat",
+ "source": "E:\\Note\\src\\app\\src\\main\\res\\menu\\note_list_options.xml"
+ },
+ {
+ "merged": "E:\\Note\\src\\app\\build\\intermediates\\res\\merged\\debug\\xml_widget_2x_info.xml.flat",
+ "source": "E:\\Note\\src\\app\\src\\main\\res\\xml\\widget_2x_info.xml"
+ },
+ {
+ "merged": "E:\\Note\\src\\app\\build\\intermediates\\res\\merged\\debug\\layout_widget_4x.xml.flat",
+ "source": "E:\\Note\\src\\app\\src\\main\\res\\layout\\widget_4x.xml"
+ },
+ {
+ "merged": "E:\\Note\\src\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_delete.png.flat",
+ "source": "E:\\Note\\src\\app\\src\\main\\res\\drawable-hdpi\\delete.png"
+ },
+ {
+ "merged": "E:\\Note\\src\\app\\build\\intermediates\\res\\merged\\debug\\raw_gestures.txt.flat",
+ "source": "E:\\Note\\src\\app\\src\\main\\res\\raw\\gestures.txt"
+ },
+ {
+ "merged": "E:\\Note\\src\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_list_red_up.9.png.flat",
+ "source": "E:\\Note\\src\\app\\src\\main\\res\\drawable-hdpi\\list_red_up.9.png"
+ },
+ {
+ "merged": "E:\\Note\\src\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_font_large.png.flat",
+ "source": "E:\\Note\\src\\app\\src\\main\\res\\drawable-hdpi\\font_large.png"
+ },
+ {
+ "merged": "E:\\Note\\src\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_list_blue_single.9.png.flat",
+ "source": "E:\\Note\\src\\app\\src\\main\\res\\drawable-hdpi\\list_blue_single.9.png"
+ },
+ {
+ "merged": "E:\\Note\\src\\app\\build\\intermediates\\res\\merged\\debug\\layout_note_edit_list_item.xml.flat",
+ "source": "E:\\Note\\src\\app\\src\\main\\res\\layout\\note_edit_list_item.xml"
+ },
+ {
+ "merged": "E:\\Note\\src\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_title_bar_bg.9.png.flat",
+ "source": "E:\\Note\\src\\app\\src\\main\\res\\drawable-hdpi\\title_bar_bg.9.png"
+ },
+ {
+ "merged": "E:\\Note\\src\\app\\build\\intermediates\\res\\merged\\debug\\layout_note_list.xml.flat",
+ "source": "E:\\Note\\src\\app\\src\\main\\res\\layout\\note_list.xml"
+ },
+ {
+ "merged": "E:\\Note\\src\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_font_normal.png.flat",
+ "source": "E:\\Note\\src\\app\\src\\main\\res\\drawable-hdpi\\font_normal.png"
+ },
+ {
+ "merged": "E:\\Note\\src\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_menu_delete.png.flat",
+ "source": "E:\\Note\\src\\app\\src\\main\\res\\drawable-hdpi\\menu_delete.png"
+ },
+ {
+ "merged": "E:\\Note\\src\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_search_result.png.flat",
+ "source": "E:\\Note\\src\\app\\src\\main\\res\\drawable-hdpi\\search_result.png"
+ },
+ {
+ "merged": "E:\\Note\\src\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_widget_4x_green.png.flat",
+ "source": "E:\\Note\\src\\app\\src\\main\\res\\drawable-hdpi\\widget_4x_green.png"
+ },
+ {
+ "merged": "E:\\Note\\src\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_list_folder.9.png.flat",
+ "source": "E:\\Note\\src\\app\\src\\main\\res\\drawable-hdpi\\list_folder.9.png"
+ },
+ {
+ "merged": "E:\\Note\\src\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_list_yellow_single.9.png.flat",
+ "source": "E:\\Note\\src\\app\\src\\main\\res\\drawable-hdpi\\list_yellow_single.9.png"
+ },
+ {
+ "merged": "E:\\Note\\src\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_widget_4x_blue.png.flat",
+ "source": "E:\\Note\\src\\app\\src\\main\\res\\drawable-hdpi\\widget_4x_blue.png"
+ },
+ {
+ "merged": "E:\\Note\\src\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_selected.png.flat",
+ "source": "E:\\Note\\src\\app\\src\\main\\res\\drawable-hdpi\\selected.png"
+ },
+ {
+ "merged": "E:\\Note\\src\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_widget_4x_red.png.flat",
+ "source": "E:\\Note\\src\\app\\src\\main\\res\\drawable-hdpi\\widget_4x_red.png"
+ },
+ {
+ "merged": "E:\\Note\\src\\app\\build\\intermediates\\res\\merged\\debug\\layout_myboard.xml.flat",
+ "source": "E:\\Note\\src\\app\\src\\main\\res\\layout\\myboard.xml"
+ },
+ {
+ "merged": "E:\\Note\\src\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_dropdown_icon.9.png.flat",
+ "source": "E:\\Note\\src\\app\\src\\main\\res\\drawable-hdpi\\dropdown_icon.9.png"
+ },
+ {
+ "merged": "E:\\Note\\src\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_call_record.png.flat",
+ "source": "E:\\Note\\src\\app\\src\\main\\res\\drawable-hdpi\\call_record.png"
+ },
+ {
+ "merged": "E:\\Note\\src\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_widget_2x_green.png.flat",
+ "source": "E:\\Note\\src\\app\\src\\main\\res\\drawable-hdpi\\widget_2x_green.png"
+ },
+ {
+ "merged": "E:\\Note\\src\\app\\build\\intermediates\\res\\merged\\debug\\layout_add_account_text.xml.flat",
+ "source": "E:\\Note\\src\\app\\src\\main\\res\\layout\\add_account_text.xml"
+ },
+ {
+ "merged": "E:\\Note\\src\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_edit_yellow.9.png.flat",
+ "source": "E:\\Note\\src\\app\\src\\main\\res\\drawable-hdpi\\edit_yellow.9.png"
+ },
+ {
+ "merged": "E:\\Note\\src\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_key.png.flat",
+ "source": "E:\\Note\\src\\app\\src\\main\\res\\drawable-hdpi\\key.png"
+ },
+ {
+ "merged": "E:\\Note\\src\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_list_background.png.flat",
+ "source": "E:\\Note\\src\\app\\src\\main\\res\\drawable-hdpi\\list_background.png"
+ },
+ {
+ "merged": "E:\\Note\\src\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_list_green_down.9.png.flat",
+ "source": "E:\\Note\\src\\app\\src\\main\\res\\drawable-hdpi\\list_green_down.9.png"
+ },
+ {
+ "merged": "E:\\Note\\src\\app\\build\\intermediates\\res\\merged\\debug\\menu_note_edit.xml.flat",
+ "source": "E:\\Note\\src\\app\\src\\main\\res\\menu\\note_edit.xml"
+ },
+ {
+ "merged": "E:\\Note\\src\\app\\build\\intermediates\\res\\merged\\debug\\menu_note_list.xml.flat",
+ "source": "E:\\Note\\src\\app\\src\\main\\res\\menu\\note_list.xml"
+ },
+ {
+ "merged": "E:\\Note\\src\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_edit_title_red.9.png.flat",
+ "source": "E:\\Note\\src\\app\\src\\main\\res\\drawable-hdpi\\edit_title_red.9.png"
+ },
+ {
+ "merged": "E:\\Note\\src\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_list_yellow_up.9.png.flat",
+ "source": "E:\\Note\\src\\app\\src\\main\\res\\drawable-hdpi\\list_yellow_up.9.png"
+ },
+ {
+ "merged": "E:\\Note\\src\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_list_blue_down.9.png.flat",
+ "source": "E:\\Note\\src\\app\\src\\main\\res\\drawable-hdpi\\list_blue_down.9.png"
+ },
+ {
+ "merged": "E:\\Note\\src\\app\\build\\intermediates\\res\\merged\\debug\\layout_account_dialog_title.xml.flat",
+ "source": "E:\\Note\\src\\app\\src\\main\\res\\layout\\account_dialog_title.xml"
+ },
+ {
+ "merged": "E:\\Note\\src\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_widget_2x_white.png.flat",
+ "source": "E:\\Note\\src\\app\\src\\main\\res\\drawable-hdpi\\widget_2x_white.png"
+ },
+ {
+ "merged": "E:\\Note\\src\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_list_white_middle.9.png.flat",
+ "source": "E:\\Note\\src\\app\\src\\main\\res\\drawable-hdpi\\list_white_middle.9.png"
+ },
+ {
+ "merged": "E:\\Note\\src\\app\\build\\intermediates\\res\\merged\\debug\\layout_note_item.xml.flat",
+ "source": "E:\\Note\\src\\app\\src\\main\\res\\layout\\note_item.xml"
+ },
+ {
+ "merged": "E:\\Note\\src\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_font_size_selector_bg.9.png.flat",
+ "source": "E:\\Note\\src\\app\\src\\main\\res\\drawable-hdpi\\font_size_selector_bg.9.png"
+ },
+ {
+ "merged": "E:\\Note\\src\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_font_super.png.flat",
+ "source": "E:\\Note\\src\\app\\src\\main\\res\\drawable-hdpi\\font_super.png"
+ },
+ {
+ "merged": "E:\\Note\\src\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_widget_2x_blue.png.flat",
+ "source": "E:\\Note\\src\\app\\src\\main\\res\\drawable-hdpi\\widget_2x_blue.png"
+ },
+ {
+ "merged": "E:\\Note\\src\\app\\build\\intermediates\\res\\merged\\debug\\menu_call_record_folder.xml.flat",
+ "source": "E:\\Note\\src\\app\\src\\main\\res\\menu\\call_record_folder.xml"
+ },
+ {
+ "merged": "E:\\Note\\src\\app\\build\\intermediates\\res\\merged\\debug\\layout_dialog_pwd_confirm.xml.flat",
+ "source": "E:\\Note\\src\\app\\src\\main\\res\\layout\\dialog_pwd_confirm.xml"
+ },
+ {
+ "merged": "E:\\Note\\src\\app\\build\\intermediates\\res\\merged\\debug\\layout_note_list_dropdown_menu.xml.flat",
+ "source": "E:\\Note\\src\\app\\src\\main\\res\\layout\\note_list_dropdown_menu.xml"
+ },
+ {
+ "merged": "E:\\Note\\src\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_notification.png.flat",
+ "source": "E:\\Note\\src\\app\\src\\main\\res\\drawable-hdpi\\notification.png"
+ },
+ {
+ "merged": "E:\\Note\\src\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_bg_color_btn_mask.png.flat",
+ "source": "E:\\Note\\src\\app\\src\\main\\res\\drawable-hdpi\\bg_color_btn_mask.png"
+ },
+ {
+ "merged": "E:\\Note\\src\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_list_red_single.9.png.flat",
+ "source": "E:\\Note\\src\\app\\src\\main\\res\\drawable-hdpi\\list_red_single.9.png"
+ },
+ {
+ "merged": "E:\\Note\\src\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_new_note_pressed.png.flat",
+ "source": "E:\\Note\\src\\app\\src\\main\\res\\drawable-hdpi\\new_note_pressed.png"
+ },
+ {
+ "merged": "E:\\Note\\src\\app\\build\\intermediates\\res\\merged\\debug\\layout_dialog_pwd.xml.flat",
+ "source": "E:\\Note\\src\\app\\src\\main\\res\\layout\\dialog_pwd.xml"
+ },
+ {
+ "merged": "E:\\Note\\src\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_list_white_single.9.png.flat",
+ "source": "E:\\Note\\src\\app\\src\\main\\res\\drawable-hdpi\\list_white_single.9.png"
+ },
+ {
+ "merged": "E:\\Note\\src\\app\\build\\intermediates\\res\\merged\\debug\\color_primary_text_dark.xml.flat",
+ "source": "E:\\Note\\src\\app\\src\\main\\res\\color\\primary_text_dark.xml"
+ },
+ {
+ "merged": "E:\\Note\\src\\app\\build\\intermediates\\res\\merged\\debug\\raw_event.txt.flat",
+ "source": "E:\\Note\\src\\app\\src\\main\\res\\raw\\event.txt"
+ },
+ {
+ "merged": "E:\\Note\\src\\app\\build\\intermediates\\res\\merged\\debug\\xml_preferences.xml.flat",
+ "source": "E:\\Note\\src\\app\\src\\main\\res\\xml\\preferences.xml"
+ },
+ {
+ "merged": "E:\\Note\\src\\app\\build\\intermediates\\res\\merged\\debug\\raw_contact.txt.flat",
+ "source": "E:\\Note\\src\\app\\src\\main\\res\\raw\\contact.txt"
+ },
+ {
+ "merged": "E:\\Note\\src\\app\\build\\intermediates\\res\\merged\\debug\\menu_note_list_dropdown.xml.flat",
+ "source": "E:\\Note\\src\\app\\src\\main\\res\\menu\\note_list_dropdown.xml"
+ },
+ {
+ "merged": "E:\\Note\\src\\app\\build\\intermediates\\res\\merged\\debug\\raw-zh-rCN_gestures.txt.flat",
+ "source": "E:\\Note\\src\\app\\src\\main\\res\\raw-zh-rCN\\gestures.txt"
+ },
+ {
+ "merged": "E:\\Note\\src\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_widget_2x_red.png.flat",
+ "source": "E:\\Note\\src\\app\\src\\main\\res\\drawable-hdpi\\widget_2x_red.png"
+ },
+ {
+ "merged": "E:\\Note\\src\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_list_red_middle.9.png.flat",
+ "source": "E:\\Note\\src\\app\\src\\main\\res\\drawable-hdpi\\list_red_middle.9.png"
+ },
+ {
+ "merged": "E:\\Note\\src\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_edit_title_yellow.9.png.flat",
+ "source": "E:\\Note\\src\\app\\src\\main\\res\\drawable-hdpi\\edit_title_yellow.9.png"
+ },
+ {
+ "merged": "E:\\Note\\src\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_edit_title_white.9.png.flat",
+ "source": "E:\\Note\\src\\app\\src\\main\\res\\drawable-hdpi\\edit_title_white.9.png"
+ },
+ {
+ "merged": "E:\\Note\\src\\app\\build\\intermediates\\res\\merged\\debug\\raw_introduction.flat",
+ "source": "E:\\Note\\src\\app\\src\\main\\res\\raw\\introduction"
+ },
+ {
+ "merged": "E:\\Note\\src\\app\\build\\intermediates\\res\\merged\\debug\\menu_sub_folder.xml.flat",
+ "source": "E:\\Note\\src\\app\\src\\main\\res\\menu\\sub_folder.xml"
+ },
+ {
+ "merged": "E:\\Note\\src\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_list_yellow_down.9.png.flat",
+ "source": "E:\\Note\\src\\app\\src\\main\\res\\drawable-hdpi\\list_yellow_down.9.png"
+ },
+ {
+ "merged": "E:\\Note\\src\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_edit_white.9.png.flat",
+ "source": "E:\\Note\\src\\app\\src\\main\\res\\drawable-hdpi\\edit_white.9.png"
+ },
+ {
+ "merged": "E:\\Note\\src\\app\\build\\intermediates\\res\\merged\\debug\\raw-zh-rCN_passwd.txt.flat",
+ "source": "E:\\Note\\src\\app\\src\\main\\res\\raw-zh-rCN\\passwd.txt"
+ },
+ {
+ "merged": "E:\\Note\\src\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_list_yellow_middle.9.png.flat",
+ "source": "E:\\Note\\src\\app\\src\\main\\res\\drawable-hdpi\\list_yellow_middle.9.png"
+ },
+ {
+ "merged": "E:\\Note\\src\\app\\build\\intermediates\\res\\merged\\debug\\raw-zh-rCN_contact.txt.flat",
+ "source": "E:\\Note\\src\\app\\src\\main\\res\\raw-zh-rCN\\contact.txt"
+ },
+ {
+ "merged": "E:\\Note\\src\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_menu_move.png.flat",
+ "source": "E:\\Note\\src\\app\\src\\main\\res\\drawable-hdpi\\menu_move.png"
+ },
+ {
+ "merged": "E:\\Note\\src\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_list_red_down.9.png.flat",
+ "source": "E:\\Note\\src\\app\\src\\main\\res\\drawable-hdpi\\list_red_down.9.png"
+ },
+ {
+ "merged": "E:\\Note\\src\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_huaban.PNG.flat",
+ "source": "E:\\Note\\src\\app\\src\\main\\res\\drawable-hdpi\\huaban.PNG"
+ },
+ {
+ "merged": "E:\\Note\\src\\app\\build\\intermediates\\res\\merged\\debug\\layout_datetime_picker.xml.flat",
+ "source": "E:\\Note\\src\\app\\src\\main\\res\\layout\\datetime_picker.xml"
+ },
+ {
+ "merged": "E:\\Note\\src\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_edit_blue.9.png.flat",
+ "source": "E:\\Note\\src\\app\\src\\main\\res\\drawable-hdpi\\edit_blue.9.png"
+ },
+ {
+ "merged": "E:\\Note\\src\\app\\build\\intermediates\\res\\merged\\debug\\layout_note_list_footer.xml.flat",
+ "source": "E:\\Note\\src\\app\\src\\main\\res\\layout\\note_list_footer.xml"
+ },
+ {
+ "merged": "E:\\Note\\src\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_widget_4x_white.png.flat",
+ "source": "E:\\Note\\src\\app\\src\\main\\res\\drawable-hdpi\\widget_4x_white.png"
+ },
+ {
+ "merged": "E:\\Note\\src\\app\\build\\intermediates\\res\\merged\\debug\\layout_settings_header.xml.flat",
+ "source": "E:\\Note\\src\\app\\src\\main\\res\\layout\\settings_header.xml"
+ },
+ {
+ "merged": "E:\\Note\\src\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_edit_title_blue.9.png.flat",
+ "source": "E:\\Note\\src\\app\\src\\main\\res\\drawable-hdpi\\edit_title_blue.9.png"
+ },
+ {
+ "merged": "E:\\Note\\src\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_clock.png.flat",
+ "source": "E:\\Note\\src\\app\\src\\main\\res\\drawable-hdpi\\clock.png"
+ },
+ {
+ "merged": "E:\\Note\\src\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_new_note_normal.png.flat",
+ "source": "E:\\Note\\src\\app\\src\\main\\res\\drawable-hdpi\\new_note_normal.png"
+ },
+ {
+ "merged": "E:\\Note\\src\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_list_blue_middle.9.png.flat",
+ "source": "E:\\Note\\src\\app\\src\\main\\res\\drawable-hdpi\\list_blue_middle.9.png"
+ },
+ {
+ "merged": "E:\\Note\\src\\app\\build\\intermediates\\res\\merged\\debug\\xml_searchable.xml.flat",
+ "source": "E:\\Note\\src\\app\\src\\main\\res\\xml\\searchable.xml"
+ },
+ {
+ "merged": "E:\\Note\\src\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_list_white_up.9.png.flat",
+ "source": "E:\\Note\\src\\app\\src\\main\\res\\drawable-hdpi\\list_white_up.9.png"
+ },
+ {
+ "merged": "E:\\Note\\src\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_edit_title_green.9.png.flat",
+ "source": "E:\\Note\\src\\app\\src\\main\\res\\drawable-hdpi\\edit_title_green.9.png"
+ },
+ {
+ "merged": "E:\\Note\\src\\app\\build\\intermediates\\res\\merged\\debug\\xml_widget_4x_info.xml.flat",
+ "source": "E:\\Note\\src\\app\\src\\main\\res\\xml\\widget_4x_info.xml"
+ },
+ {
+ "merged": "E:\\Note\\src\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_list_blue_up.9.png.flat",
+ "source": "E:\\Note\\src\\app\\src\\main\\res\\drawable-hdpi\\list_blue_up.9.png"
+ },
+ {
+ "merged": "E:\\Note\\src\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_edit_green.9.png.flat",
+ "source": "E:\\Note\\src\\app\\src\\main\\res\\drawable-hdpi\\edit_green.9.png"
+ },
+ {
+ "merged": "E:\\Note\\src\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_list_green_up.9.png.flat",
+ "source": "E:\\Note\\src\\app\\src\\main\\res\\drawable-hdpi\\list_green_up.9.png"
+ },
+ {
+ "merged": "E:\\Note\\src\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_list_green_single.9.png.flat",
+ "source": "E:\\Note\\src\\app\\src\\main\\res\\drawable-hdpi\\list_green_single.9.png"
+ },
+ {
+ "merged": "E:\\Note\\src\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_widget_2x_yellow.png.flat",
+ "source": "E:\\Note\\src\\app\\src\\main\\res\\drawable-hdpi\\widget_2x_yellow.png"
+ },
+ {
+ "merged": "E:\\Note\\src\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_edit_red.9.png.flat",
+ "source": "E:\\Note\\src\\app\\src\\main\\res\\drawable-hdpi\\edit_red.9.png"
+ },
+ {
+ "merged": "E:\\Note\\src\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_title_alert.png.flat",
+ "source": "E:\\Note\\src\\app\\src\\main\\res\\drawable-hdpi\\title_alert.png"
+ },
+ {
+ "merged": "E:\\Note\\src\\app\\build\\intermediates\\res\\merged\\debug\\menu_call_note_edit.xml.flat",
+ "source": "E:\\Note\\src\\app\\src\\main\\res\\menu\\call_note_edit.xml"
+ },
+ {
+ "merged": "E:\\Note\\src\\app\\build\\intermediates\\res\\merged\\debug\\layout_gesture_setting.xml.flat",
+ "source": "E:\\Note\\src\\app\\src\\main\\res\\layout\\gesture_setting.xml"
+ },
+ {
+ "merged": "E:\\Note\\src\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_note_edit_color_selector_panel.png.flat",
+ "source": "E:\\Note\\src\\app\\src\\main\\res\\drawable-hdpi\\note_edit_color_selector_panel.png"
+ },
+ {
+ "merged": "E:\\Note\\src\\app\\build\\intermediates\\res\\merged\\debug\\drawable_new_note.xml.flat",
+ "source": "E:\\Note\\src\\app\\src\\main\\res\\drawable\\new_note.xml"
+ },
+ {
+ "merged": "E:\\Note\\src\\app\\build\\intermediates\\res\\merged\\debug\\raw-zh-rCN_event.txt.flat",
+ "source": "E:\\Note\\src\\app\\src\\main\\res\\raw-zh-rCN\\event.txt"
+ },
+ {
+ "merged": "E:\\Note\\src\\app\\build\\intermediates\\res\\merged\\debug\\layout_dialog_edit_text.xml.flat",
+ "source": "E:\\Note\\src\\app\\src\\main\\res\\layout\\dialog_edit_text.xml"
+ },
+ {
+ "merged": "E:\\Note\\src\\app\\build\\intermediates\\res\\merged\\debug\\layout_dialog_save.xml.flat",
+ "source": "E:\\Note\\src\\app\\src\\main\\res\\layout\\dialog_save.xml"
+ },
+ {
+ "merged": "E:\\Note\\src\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_font_small.png.flat",
+ "source": "E:\\Note\\src\\app\\src\\main\\res\\drawable-hdpi\\font_small.png"
+ },
+ {
+ "merged": "E:\\Note\\src\\app\\build\\intermediates\\res\\merged\\debug\\layout_widget_2x.xml.flat",
+ "source": "E:\\Note\\src\\app\\src\\main\\res\\layout\\widget_2x.xml"
+ },
+ {
+ "merged": "E:\\Note\\src\\app\\build\\intermediates\\res\\merged\\debug\\layout_folder_list_item.xml.flat",
+ "source": "E:\\Note\\src\\app\\src\\main\\res\\layout\\folder_list_item.xml"
+ },
+ {
+ "merged": "E:\\Note\\src\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_list_white_down.9.png.flat",
+ "source": "E:\\Note\\src\\app\\src\\main\\res\\drawable-hdpi\\list_white_down.9.png"
+ },
+ {
+ "merged": "E:\\Note\\src\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_bg_btn_set_color.png.flat",
+ "source": "E:\\Note\\src\\app\\src\\main\\res\\drawable-hdpi\\bg_btn_set_color.png"
+ },
+ {
+ "merged": "E:\\Note\\src\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_list_green_middle.9.png.flat",
+ "source": "E:\\Note\\src\\app\\src\\main\\res\\drawable-hdpi\\list_green_middle.9.png"
+ }
+]
\ No newline at end of file
diff --git a/src/src/app/build/intermediates/bundle_manifest/debug/bundle-manifest/AndroidManifest.xml b/src/src/app/build/intermediates/bundle_manifest/debug/bundle-manifest/AndroidManifest.xml
new file mode 100644
index 0000000..3fb6129
--- /dev/null
+++ b/src/src/app/build/intermediates/bundle_manifest/debug/bundle-manifest/AndroidManifest.xml
@@ -0,0 +1,169 @@
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
\ No newline at end of file
diff --git a/src/src/app/build/intermediates/bundle_manifest/debug/bundle-manifest/output.json b/src/src/app/build/intermediates/bundle_manifest/debug/bundle-manifest/output.json
new file mode 100644
index 0000000..1a93d35
--- /dev/null
+++ b/src/src/app/build/intermediates/bundle_manifest/debug/bundle-manifest/output.json
@@ -0,0 +1,28 @@
+{
+ "version": 1,
+ "applicationId": "net.micode.notes",
+ "variantType": "BASE_APK",
+ "elements": [
+ {
+ "outputType": {
+ "type": "BUNDLE_MANIFEST"
+ },
+ "apkData": {
+ "type": "MAIN",
+ "splits": [],
+ "versionCode": 1,
+ "versionName": "0.1",
+ "outputFile": "app-debug.apk",
+ "fullName": "debug",
+ "baseName": "debug",
+ "dirName": ""
+ },
+ "path": "AndroidManifest.xml",
+ "properties": {
+ "packageId": "net.micode.notes",
+ "split": "",
+ "minSdkVersion": "14"
+ }
+ }
+ ]
+}
\ No newline at end of file
diff --git a/src/src/app/build/intermediates/compatible_screen_manifest/debug/out/output.json b/src/src/app/build/intermediates/compatible_screen_manifest/debug/out/output.json
new file mode 100644
index 0000000..dd5c633
--- /dev/null
+++ b/src/src/app/build/intermediates/compatible_screen_manifest/debug/out/output.json
@@ -0,0 +1,6 @@
+{
+ "version": 1,
+ "applicationId": "net.micode.notes",
+ "variantType": "BASE_APK",
+ "elements": []
+}
\ No newline at end of file
diff --git a/src/src/app/build/intermediates/compile_and_runtime_not_namespaced_r_class_jar/debug/R.jar b/src/src/app/build/intermediates/compile_and_runtime_not_namespaced_r_class_jar/debug/R.jar
new file mode 100644
index 0000000..fadc6a9
Binary files /dev/null and b/src/src/app/build/intermediates/compile_and_runtime_not_namespaced_r_class_jar/debug/R.jar differ
diff --git a/src/src/app/build/intermediates/compile_and_runtime_not_namespaced_r_class_jar/debugAndroidTest/R.jar b/src/src/app/build/intermediates/compile_and_runtime_not_namespaced_r_class_jar/debugAndroidTest/R.jar
new file mode 100644
index 0000000..1b37bfc
Binary files /dev/null and b/src/src/app/build/intermediates/compile_and_runtime_not_namespaced_r_class_jar/debugAndroidTest/R.jar differ
diff --git a/src/src/app/build/intermediates/dex/debug/mergeDexDebug/classes.dex b/src/src/app/build/intermediates/dex/debug/mergeDexDebug/classes.dex
new file mode 100644
index 0000000..789b319
Binary files /dev/null and b/src/src/app/build/intermediates/dex/debug/mergeDexDebug/classes.dex differ
diff --git a/src/src/app/build/intermediates/dex_archive_input_jar_hashes/debug/out b/src/src/app/build/intermediates/dex_archive_input_jar_hashes/debug/out
new file mode 100644
index 0000000..bc58d25
Binary files /dev/null and b/src/src/app/build/intermediates/dex_archive_input_jar_hashes/debug/out differ
diff --git a/src/src/app/build/intermediates/external_libs_dex/debug/mergeExtDexDebug/classes.dex b/src/src/app/build/intermediates/external_libs_dex/debug/mergeExtDexDebug/classes.dex
new file mode 100644
index 0000000..ec514e4
Binary files /dev/null and b/src/src/app/build/intermediates/external_libs_dex/debug/mergeExtDexDebug/classes.dex differ
diff --git a/src/src/app/build/intermediates/incremental/debug-mergeJavaRes/merge-state b/src/src/app/build/intermediates/incremental/debug-mergeJavaRes/merge-state
new file mode 100644
index 0000000..89e5ff3
Binary files /dev/null and b/src/src/app/build/intermediates/incremental/debug-mergeJavaRes/merge-state differ
diff --git a/src/src/app/build/intermediates/incremental/debug-mergeJavaRes/zip-cache/48bq4I77xPsjTejJTjZqLQfx1GU= b/src/src/app/build/intermediates/incremental/debug-mergeJavaRes/zip-cache/48bq4I77xPsjTejJTjZqLQfx1GU=
new file mode 100644
index 0000000..b874311
Binary files /dev/null and b/src/src/app/build/intermediates/incremental/debug-mergeJavaRes/zip-cache/48bq4I77xPsjTejJTjZqLQfx1GU= differ
diff --git a/src/src/app/build/intermediates/incremental/debug-mergeJavaRes/zip-cache/6lAfJo9QE4t2CTqUBsLwBoiLLm8= b/src/src/app/build/intermediates/incremental/debug-mergeJavaRes/zip-cache/6lAfJo9QE4t2CTqUBsLwBoiLLm8=
new file mode 100644
index 0000000..45189c1
Binary files /dev/null and b/src/src/app/build/intermediates/incremental/debug-mergeJavaRes/zip-cache/6lAfJo9QE4t2CTqUBsLwBoiLLm8= differ
diff --git a/src/src/app/build/intermediates/incremental/debug-mergeJavaRes/zip-cache/8flUxHHX8+Dadv6JNpMCjA2gfps= b/src/src/app/build/intermediates/incremental/debug-mergeJavaRes/zip-cache/8flUxHHX8+Dadv6JNpMCjA2gfps=
new file mode 100644
index 0000000..ffb61da
Binary files /dev/null and b/src/src/app/build/intermediates/incremental/debug-mergeJavaRes/zip-cache/8flUxHHX8+Dadv6JNpMCjA2gfps= differ
diff --git a/src/src/app/build/intermediates/incremental/debug-mergeJavaRes/zip-cache/EefqlUVQ1wbv30LfDS84i5F5fww= b/src/src/app/build/intermediates/incremental/debug-mergeJavaRes/zip-cache/EefqlUVQ1wbv30LfDS84i5F5fww=
new file mode 100644
index 0000000..b2e1806
Binary files /dev/null and b/src/src/app/build/intermediates/incremental/debug-mergeJavaRes/zip-cache/EefqlUVQ1wbv30LfDS84i5F5fww= differ
diff --git a/src/src/app/build/intermediates/incremental/debug-mergeJavaRes/zip-cache/GxfOpz3pbrB3Wyp1Hl3d2JDlR_E= b/src/src/app/build/intermediates/incremental/debug-mergeJavaRes/zip-cache/GxfOpz3pbrB3Wyp1Hl3d2JDlR_E=
new file mode 100644
index 0000000..6c3f095
Binary files /dev/null and b/src/src/app/build/intermediates/incremental/debug-mergeJavaRes/zip-cache/GxfOpz3pbrB3Wyp1Hl3d2JDlR_E= differ
diff --git a/src/src/app/build/intermediates/incremental/debug-mergeJavaRes/zip-cache/I3O2iYDWrG2f26IhjYYzePiPt64= b/src/src/app/build/intermediates/incremental/debug-mergeJavaRes/zip-cache/I3O2iYDWrG2f26IhjYYzePiPt64=
new file mode 100644
index 0000000..6ccda32
Binary files /dev/null and b/src/src/app/build/intermediates/incremental/debug-mergeJavaRes/zip-cache/I3O2iYDWrG2f26IhjYYzePiPt64= differ
diff --git a/src/src/app/build/intermediates/incremental/debug-mergeJavaRes/zip-cache/JoDfQ4KOfgTLCAueZoEhnzEwxVA= b/src/src/app/build/intermediates/incremental/debug-mergeJavaRes/zip-cache/JoDfQ4KOfgTLCAueZoEhnzEwxVA=
new file mode 100644
index 0000000..8007b15
Binary files /dev/null and b/src/src/app/build/intermediates/incremental/debug-mergeJavaRes/zip-cache/JoDfQ4KOfgTLCAueZoEhnzEwxVA= differ
diff --git a/src/src/app/build/intermediates/incremental/debug-mergeJavaRes/zip-cache/MjkJRFCsGVtcOfeXOJ2xwHvD_Ho= b/src/src/app/build/intermediates/incremental/debug-mergeJavaRes/zip-cache/MjkJRFCsGVtcOfeXOJ2xwHvD_Ho=
new file mode 100644
index 0000000..33a6966
Binary files /dev/null and b/src/src/app/build/intermediates/incremental/debug-mergeJavaRes/zip-cache/MjkJRFCsGVtcOfeXOJ2xwHvD_Ho= differ
diff --git a/src/src/app/build/intermediates/incremental/debug-mergeJavaRes/zip-cache/NX4UbA8wI7q_QmmFlukaCqv9NPo= b/src/src/app/build/intermediates/incremental/debug-mergeJavaRes/zip-cache/NX4UbA8wI7q_QmmFlukaCqv9NPo=
new file mode 100644
index 0000000..2cec677
Binary files /dev/null and b/src/src/app/build/intermediates/incremental/debug-mergeJavaRes/zip-cache/NX4UbA8wI7q_QmmFlukaCqv9NPo= differ
diff --git a/src/src/app/build/intermediates/incremental/debug-mergeJavaRes/zip-cache/QEtDxVtd6cV5U8vMpj9sdLXwJok= b/src/src/app/build/intermediates/incremental/debug-mergeJavaRes/zip-cache/QEtDxVtd6cV5U8vMpj9sdLXwJok=
new file mode 100644
index 0000000..d05d5f7
Binary files /dev/null and b/src/src/app/build/intermediates/incremental/debug-mergeJavaRes/zip-cache/QEtDxVtd6cV5U8vMpj9sdLXwJok= differ
diff --git a/src/src/app/build/intermediates/incremental/debug-mergeJavaRes/zip-cache/QaYWXG+Abql+_+LimGbNP7UJuDI= b/src/src/app/build/intermediates/incremental/debug-mergeJavaRes/zip-cache/QaYWXG+Abql+_+LimGbNP7UJuDI=
new file mode 100644
index 0000000..8568b5b
Binary files /dev/null and b/src/src/app/build/intermediates/incremental/debug-mergeJavaRes/zip-cache/QaYWXG+Abql+_+LimGbNP7UJuDI= differ
diff --git a/src/src/app/build/intermediates/incremental/debug-mergeJavaRes/zip-cache/Sc5UtfgcHY6QNmOYXbdp004ppjY= b/src/src/app/build/intermediates/incremental/debug-mergeJavaRes/zip-cache/Sc5UtfgcHY6QNmOYXbdp004ppjY=
new file mode 100644
index 0000000..c42746e
Binary files /dev/null and b/src/src/app/build/intermediates/incremental/debug-mergeJavaRes/zip-cache/Sc5UtfgcHY6QNmOYXbdp004ppjY= differ
diff --git a/src/src/app/build/intermediates/incremental/debug-mergeJavaRes/zip-cache/ThWCo_Opi9XlQJmoKKO_oiIscak= b/src/src/app/build/intermediates/incremental/debug-mergeJavaRes/zip-cache/ThWCo_Opi9XlQJmoKKO_oiIscak=
new file mode 100644
index 0000000..8fd6cd4
Binary files /dev/null and b/src/src/app/build/intermediates/incremental/debug-mergeJavaRes/zip-cache/ThWCo_Opi9XlQJmoKKO_oiIscak= differ
diff --git a/src/src/app/build/intermediates/incremental/debug-mergeJavaRes/zip-cache/Ub1yB8hGBMnfYkT5npnasZ7Oifs= b/src/src/app/build/intermediates/incremental/debug-mergeJavaRes/zip-cache/Ub1yB8hGBMnfYkT5npnasZ7Oifs=
new file mode 100644
index 0000000..dc7b90e
Binary files /dev/null and b/src/src/app/build/intermediates/incremental/debug-mergeJavaRes/zip-cache/Ub1yB8hGBMnfYkT5npnasZ7Oifs= differ
diff --git a/src/src/app/build/intermediates/incremental/debug-mergeJavaRes/zip-cache/VqB5ayAosegDXK0voQLG1XwqzMg= b/src/src/app/build/intermediates/incremental/debug-mergeJavaRes/zip-cache/VqB5ayAosegDXK0voQLG1XwqzMg=
new file mode 100644
index 0000000..f0205ce
Binary files /dev/null and b/src/src/app/build/intermediates/incremental/debug-mergeJavaRes/zip-cache/VqB5ayAosegDXK0voQLG1XwqzMg= differ
diff --git a/src/src/app/build/intermediates/incremental/debug-mergeJavaRes/zip-cache/XFPiKYgFCt84J2DwRw3TyrdFOjg= b/src/src/app/build/intermediates/incremental/debug-mergeJavaRes/zip-cache/XFPiKYgFCt84J2DwRw3TyrdFOjg=
new file mode 100644
index 0000000..25e1933
Binary files /dev/null and b/src/src/app/build/intermediates/incremental/debug-mergeJavaRes/zip-cache/XFPiKYgFCt84J2DwRw3TyrdFOjg= differ
diff --git a/src/src/app/build/intermediates/incremental/debug-mergeJavaRes/zip-cache/XiBR7p_putCXZRidEsdxZrmNQbo= b/src/src/app/build/intermediates/incremental/debug-mergeJavaRes/zip-cache/XiBR7p_putCXZRidEsdxZrmNQbo=
new file mode 100644
index 0000000..fa4c15f
Binary files /dev/null and b/src/src/app/build/intermediates/incremental/debug-mergeJavaRes/zip-cache/XiBR7p_putCXZRidEsdxZrmNQbo= differ
diff --git a/src/src/app/build/intermediates/incremental/debug-mergeJavaRes/zip-cache/auSv992BISLvLRx5rbvAHX6b4Og= b/src/src/app/build/intermediates/incremental/debug-mergeJavaRes/zip-cache/auSv992BISLvLRx5rbvAHX6b4Og=
new file mode 100644
index 0000000..b86cf55
Binary files /dev/null and b/src/src/app/build/intermediates/incremental/debug-mergeJavaRes/zip-cache/auSv992BISLvLRx5rbvAHX6b4Og= differ
diff --git a/src/src/app/build/intermediates/incremental/debug-mergeJavaRes/zip-cache/eLKYnIHaM+WGOJhN9g0NTgzDeWQ= b/src/src/app/build/intermediates/incremental/debug-mergeJavaRes/zip-cache/eLKYnIHaM+WGOJhN9g0NTgzDeWQ=
new file mode 100644
index 0000000..30185e4
Binary files /dev/null and b/src/src/app/build/intermediates/incremental/debug-mergeJavaRes/zip-cache/eLKYnIHaM+WGOJhN9g0NTgzDeWQ= differ
diff --git a/src/src/app/build/intermediates/incremental/debug-mergeJavaRes/zip-cache/fEh_8KMJxdQREWeur1Sfdi_W5yc= b/src/src/app/build/intermediates/incremental/debug-mergeJavaRes/zip-cache/fEh_8KMJxdQREWeur1Sfdi_W5yc=
new file mode 100644
index 0000000..71460a1
Binary files /dev/null and b/src/src/app/build/intermediates/incremental/debug-mergeJavaRes/zip-cache/fEh_8KMJxdQREWeur1Sfdi_W5yc= differ
diff --git a/src/src/app/build/intermediates/incremental/debug-mergeJavaRes/zip-cache/gXRoDsR+GuWPJ9bzX6qw4G5SJ2M= b/src/src/app/build/intermediates/incremental/debug-mergeJavaRes/zip-cache/gXRoDsR+GuWPJ9bzX6qw4G5SJ2M=
new file mode 100644
index 0000000..98ec886
Binary files /dev/null and b/src/src/app/build/intermediates/incremental/debug-mergeJavaRes/zip-cache/gXRoDsR+GuWPJ9bzX6qw4G5SJ2M= differ
diff --git a/src/src/app/build/intermediates/incremental/debug-mergeJavaRes/zip-cache/gkStxGAQSDhtyZtix1IZG1zsxDw= b/src/src/app/build/intermediates/incremental/debug-mergeJavaRes/zip-cache/gkStxGAQSDhtyZtix1IZG1zsxDw=
new file mode 100644
index 0000000..5707aa8
Binary files /dev/null and b/src/src/app/build/intermediates/incremental/debug-mergeJavaRes/zip-cache/gkStxGAQSDhtyZtix1IZG1zsxDw= differ
diff --git a/src/src/app/build/intermediates/incremental/debug-mergeJavaRes/zip-cache/lyRVovPySTb7TeFVFnNLaAlpoS4= b/src/src/app/build/intermediates/incremental/debug-mergeJavaRes/zip-cache/lyRVovPySTb7TeFVFnNLaAlpoS4=
new file mode 100644
index 0000000..144d863
Binary files /dev/null and b/src/src/app/build/intermediates/incremental/debug-mergeJavaRes/zip-cache/lyRVovPySTb7TeFVFnNLaAlpoS4= differ
diff --git a/src/src/app/build/intermediates/incremental/debug-mergeJavaRes/zip-cache/nAb55gm3YU81lnP+fvYaYHx6B0M= b/src/src/app/build/intermediates/incremental/debug-mergeJavaRes/zip-cache/nAb55gm3YU81lnP+fvYaYHx6B0M=
new file mode 100644
index 0000000..d0a17a9
Binary files /dev/null and b/src/src/app/build/intermediates/incremental/debug-mergeJavaRes/zip-cache/nAb55gm3YU81lnP+fvYaYHx6B0M= differ
diff --git a/src/src/app/build/intermediates/incremental/debug-mergeJavaRes/zip-cache/ocjNiVEzzEflMVsDyf1gN_b8PSU= b/src/src/app/build/intermediates/incremental/debug-mergeJavaRes/zip-cache/ocjNiVEzzEflMVsDyf1gN_b8PSU=
new file mode 100644
index 0000000..78ac06c
Binary files /dev/null and b/src/src/app/build/intermediates/incremental/debug-mergeJavaRes/zip-cache/ocjNiVEzzEflMVsDyf1gN_b8PSU= differ
diff --git a/src/src/app/build/intermediates/incremental/debug-mergeJavaRes/zip-cache/p7F0a25_zIzPcZpo0DvqEI6SuPA= b/src/src/app/build/intermediates/incremental/debug-mergeJavaRes/zip-cache/p7F0a25_zIzPcZpo0DvqEI6SuPA=
new file mode 100644
index 0000000..de755d1
Binary files /dev/null and b/src/src/app/build/intermediates/incremental/debug-mergeJavaRes/zip-cache/p7F0a25_zIzPcZpo0DvqEI6SuPA= differ
diff --git a/src/src/app/build/intermediates/incremental/debug-mergeJavaRes/zip-cache/qlW4RXtuoAOh8prM7UIbLGg6ra0= b/src/src/app/build/intermediates/incremental/debug-mergeJavaRes/zip-cache/qlW4RXtuoAOh8prM7UIbLGg6ra0=
new file mode 100644
index 0000000..c3eef53
Binary files /dev/null and b/src/src/app/build/intermediates/incremental/debug-mergeJavaRes/zip-cache/qlW4RXtuoAOh8prM7UIbLGg6ra0= differ
diff --git a/src/src/app/build/intermediates/incremental/debug-mergeJavaRes/zip-cache/sG0ONBeGIaJqnbfYbE4esMb9Sso= b/src/src/app/build/intermediates/incremental/debug-mergeJavaRes/zip-cache/sG0ONBeGIaJqnbfYbE4esMb9Sso=
new file mode 100644
index 0000000..f1f7e72
Binary files /dev/null and b/src/src/app/build/intermediates/incremental/debug-mergeJavaRes/zip-cache/sG0ONBeGIaJqnbfYbE4esMb9Sso= differ
diff --git a/src/src/app/build/intermediates/incremental/debug-mergeJavaRes/zip-cache/uPowm7BGJNBEKRUS7A8Ur5AkKHI= b/src/src/app/build/intermediates/incremental/debug-mergeJavaRes/zip-cache/uPowm7BGJNBEKRUS7A8Ur5AkKHI=
new file mode 100644
index 0000000..22a6ffc
Binary files /dev/null and b/src/src/app/build/intermediates/incremental/debug-mergeJavaRes/zip-cache/uPowm7BGJNBEKRUS7A8Ur5AkKHI= differ
diff --git a/src/src/app/build/intermediates/incremental/debug-mergeJavaRes/zip-cache/uU2FTnf3Id0bFvmgrJNqLePreZg= b/src/src/app/build/intermediates/incremental/debug-mergeJavaRes/zip-cache/uU2FTnf3Id0bFvmgrJNqLePreZg=
new file mode 100644
index 0000000..846dea1
Binary files /dev/null and b/src/src/app/build/intermediates/incremental/debug-mergeJavaRes/zip-cache/uU2FTnf3Id0bFvmgrJNqLePreZg= differ
diff --git a/src/src/app/build/intermediates/incremental/debug-mergeJavaRes/zip-cache/w5kxRPvLKqY3B4AS2ZWWVCc4qZE= b/src/src/app/build/intermediates/incremental/debug-mergeJavaRes/zip-cache/w5kxRPvLKqY3B4AS2ZWWVCc4qZE=
new file mode 100644
index 0000000..124f128
Binary files /dev/null and b/src/src/app/build/intermediates/incremental/debug-mergeJavaRes/zip-cache/w5kxRPvLKqY3B4AS2ZWWVCc4qZE= differ
diff --git a/src/src/app/build/intermediates/incremental/debug-mergeJavaRes/zip-cache/wZ8evydlCdpjbmGpUvTZJFomdJU= b/src/src/app/build/intermediates/incremental/debug-mergeJavaRes/zip-cache/wZ8evydlCdpjbmGpUvTZJFomdJU=
new file mode 100644
index 0000000..189e23f
Binary files /dev/null and b/src/src/app/build/intermediates/incremental/debug-mergeJavaRes/zip-cache/wZ8evydlCdpjbmGpUvTZJFomdJU= differ
diff --git a/src/src/app/build/intermediates/incremental/debug-mergeNativeLibs/merge-state b/src/src/app/build/intermediates/incremental/debug-mergeNativeLibs/merge-state
new file mode 100644
index 0000000..98fed81
Binary files /dev/null and b/src/src/app/build/intermediates/incremental/debug-mergeNativeLibs/merge-state differ
diff --git a/src/src/app/build/intermediates/incremental/debug-mergeNativeLibs/zip-cache/48bq4I77xPsjTejJTjZqLQfx1GU= b/src/src/app/build/intermediates/incremental/debug-mergeNativeLibs/zip-cache/48bq4I77xPsjTejJTjZqLQfx1GU=
new file mode 100644
index 0000000..b874311
Binary files /dev/null and b/src/src/app/build/intermediates/incremental/debug-mergeNativeLibs/zip-cache/48bq4I77xPsjTejJTjZqLQfx1GU= differ
diff --git a/src/src/app/build/intermediates/incremental/debug-mergeNativeLibs/zip-cache/6lAfJo9QE4t2CTqUBsLwBoiLLm8= b/src/src/app/build/intermediates/incremental/debug-mergeNativeLibs/zip-cache/6lAfJo9QE4t2CTqUBsLwBoiLLm8=
new file mode 100644
index 0000000..45189c1
Binary files /dev/null and b/src/src/app/build/intermediates/incremental/debug-mergeNativeLibs/zip-cache/6lAfJo9QE4t2CTqUBsLwBoiLLm8= differ
diff --git a/src/src/app/build/intermediates/incremental/debug-mergeNativeLibs/zip-cache/8flUxHHX8+Dadv6JNpMCjA2gfps= b/src/src/app/build/intermediates/incremental/debug-mergeNativeLibs/zip-cache/8flUxHHX8+Dadv6JNpMCjA2gfps=
new file mode 100644
index 0000000..ffb61da
Binary files /dev/null and b/src/src/app/build/intermediates/incremental/debug-mergeNativeLibs/zip-cache/8flUxHHX8+Dadv6JNpMCjA2gfps= differ
diff --git a/src/src/app/build/intermediates/incremental/debug-mergeNativeLibs/zip-cache/EefqlUVQ1wbv30LfDS84i5F5fww= b/src/src/app/build/intermediates/incremental/debug-mergeNativeLibs/zip-cache/EefqlUVQ1wbv30LfDS84i5F5fww=
new file mode 100644
index 0000000..b2e1806
Binary files /dev/null and b/src/src/app/build/intermediates/incremental/debug-mergeNativeLibs/zip-cache/EefqlUVQ1wbv30LfDS84i5F5fww= differ
diff --git a/src/src/app/build/intermediates/incremental/debug-mergeNativeLibs/zip-cache/GxfOpz3pbrB3Wyp1Hl3d2JDlR_E= b/src/src/app/build/intermediates/incremental/debug-mergeNativeLibs/zip-cache/GxfOpz3pbrB3Wyp1Hl3d2JDlR_E=
new file mode 100644
index 0000000..6c3f095
Binary files /dev/null and b/src/src/app/build/intermediates/incremental/debug-mergeNativeLibs/zip-cache/GxfOpz3pbrB3Wyp1Hl3d2JDlR_E= differ
diff --git a/src/src/app/build/intermediates/incremental/debug-mergeNativeLibs/zip-cache/I3O2iYDWrG2f26IhjYYzePiPt64= b/src/src/app/build/intermediates/incremental/debug-mergeNativeLibs/zip-cache/I3O2iYDWrG2f26IhjYYzePiPt64=
new file mode 100644
index 0000000..6ccda32
Binary files /dev/null and b/src/src/app/build/intermediates/incremental/debug-mergeNativeLibs/zip-cache/I3O2iYDWrG2f26IhjYYzePiPt64= differ
diff --git a/src/src/app/build/intermediates/incremental/debug-mergeNativeLibs/zip-cache/JoDfQ4KOfgTLCAueZoEhnzEwxVA= b/src/src/app/build/intermediates/incremental/debug-mergeNativeLibs/zip-cache/JoDfQ4KOfgTLCAueZoEhnzEwxVA=
new file mode 100644
index 0000000..8007b15
Binary files /dev/null and b/src/src/app/build/intermediates/incremental/debug-mergeNativeLibs/zip-cache/JoDfQ4KOfgTLCAueZoEhnzEwxVA= differ
diff --git a/src/src/app/build/intermediates/incremental/debug-mergeNativeLibs/zip-cache/MjkJRFCsGVtcOfeXOJ2xwHvD_Ho= b/src/src/app/build/intermediates/incremental/debug-mergeNativeLibs/zip-cache/MjkJRFCsGVtcOfeXOJ2xwHvD_Ho=
new file mode 100644
index 0000000..33a6966
Binary files /dev/null and b/src/src/app/build/intermediates/incremental/debug-mergeNativeLibs/zip-cache/MjkJRFCsGVtcOfeXOJ2xwHvD_Ho= differ
diff --git a/src/src/app/build/intermediates/incremental/debug-mergeNativeLibs/zip-cache/NX4UbA8wI7q_QmmFlukaCqv9NPo= b/src/src/app/build/intermediates/incremental/debug-mergeNativeLibs/zip-cache/NX4UbA8wI7q_QmmFlukaCqv9NPo=
new file mode 100644
index 0000000..2cec677
Binary files /dev/null and b/src/src/app/build/intermediates/incremental/debug-mergeNativeLibs/zip-cache/NX4UbA8wI7q_QmmFlukaCqv9NPo= differ
diff --git a/src/src/app/build/intermediates/incremental/debug-mergeNativeLibs/zip-cache/QEtDxVtd6cV5U8vMpj9sdLXwJok= b/src/src/app/build/intermediates/incremental/debug-mergeNativeLibs/zip-cache/QEtDxVtd6cV5U8vMpj9sdLXwJok=
new file mode 100644
index 0000000..d05d5f7
Binary files /dev/null and b/src/src/app/build/intermediates/incremental/debug-mergeNativeLibs/zip-cache/QEtDxVtd6cV5U8vMpj9sdLXwJok= differ
diff --git a/src/src/app/build/intermediates/incremental/debug-mergeNativeLibs/zip-cache/QaYWXG+Abql+_+LimGbNP7UJuDI= b/src/src/app/build/intermediates/incremental/debug-mergeNativeLibs/zip-cache/QaYWXG+Abql+_+LimGbNP7UJuDI=
new file mode 100644
index 0000000..8568b5b
Binary files /dev/null and b/src/src/app/build/intermediates/incremental/debug-mergeNativeLibs/zip-cache/QaYWXG+Abql+_+LimGbNP7UJuDI= differ
diff --git a/src/src/app/build/intermediates/incremental/debug-mergeNativeLibs/zip-cache/Sc5UtfgcHY6QNmOYXbdp004ppjY= b/src/src/app/build/intermediates/incremental/debug-mergeNativeLibs/zip-cache/Sc5UtfgcHY6QNmOYXbdp004ppjY=
new file mode 100644
index 0000000..c42746e
Binary files /dev/null and b/src/src/app/build/intermediates/incremental/debug-mergeNativeLibs/zip-cache/Sc5UtfgcHY6QNmOYXbdp004ppjY= differ
diff --git a/src/src/app/build/intermediates/incremental/debug-mergeNativeLibs/zip-cache/ThWCo_Opi9XlQJmoKKO_oiIscak= b/src/src/app/build/intermediates/incremental/debug-mergeNativeLibs/zip-cache/ThWCo_Opi9XlQJmoKKO_oiIscak=
new file mode 100644
index 0000000..8fd6cd4
Binary files /dev/null and b/src/src/app/build/intermediates/incremental/debug-mergeNativeLibs/zip-cache/ThWCo_Opi9XlQJmoKKO_oiIscak= differ
diff --git a/src/src/app/build/intermediates/incremental/debug-mergeNativeLibs/zip-cache/Ub1yB8hGBMnfYkT5npnasZ7Oifs= b/src/src/app/build/intermediates/incremental/debug-mergeNativeLibs/zip-cache/Ub1yB8hGBMnfYkT5npnasZ7Oifs=
new file mode 100644
index 0000000..dc7b90e
Binary files /dev/null and b/src/src/app/build/intermediates/incremental/debug-mergeNativeLibs/zip-cache/Ub1yB8hGBMnfYkT5npnasZ7Oifs= differ
diff --git a/src/src/app/build/intermediates/incremental/debug-mergeNativeLibs/zip-cache/VqB5ayAosegDXK0voQLG1XwqzMg= b/src/src/app/build/intermediates/incremental/debug-mergeNativeLibs/zip-cache/VqB5ayAosegDXK0voQLG1XwqzMg=
new file mode 100644
index 0000000..f0205ce
Binary files /dev/null and b/src/src/app/build/intermediates/incremental/debug-mergeNativeLibs/zip-cache/VqB5ayAosegDXK0voQLG1XwqzMg= differ
diff --git a/src/src/app/build/intermediates/incremental/debug-mergeNativeLibs/zip-cache/XFPiKYgFCt84J2DwRw3TyrdFOjg= b/src/src/app/build/intermediates/incremental/debug-mergeNativeLibs/zip-cache/XFPiKYgFCt84J2DwRw3TyrdFOjg=
new file mode 100644
index 0000000..25e1933
Binary files /dev/null and b/src/src/app/build/intermediates/incremental/debug-mergeNativeLibs/zip-cache/XFPiKYgFCt84J2DwRw3TyrdFOjg= differ
diff --git a/src/src/app/build/intermediates/incremental/debug-mergeNativeLibs/zip-cache/XiBR7p_putCXZRidEsdxZrmNQbo= b/src/src/app/build/intermediates/incremental/debug-mergeNativeLibs/zip-cache/XiBR7p_putCXZRidEsdxZrmNQbo=
new file mode 100644
index 0000000..fa4c15f
Binary files /dev/null and b/src/src/app/build/intermediates/incremental/debug-mergeNativeLibs/zip-cache/XiBR7p_putCXZRidEsdxZrmNQbo= differ
diff --git a/src/src/app/build/intermediates/incremental/debug-mergeNativeLibs/zip-cache/auSv992BISLvLRx5rbvAHX6b4Og= b/src/src/app/build/intermediates/incremental/debug-mergeNativeLibs/zip-cache/auSv992BISLvLRx5rbvAHX6b4Og=
new file mode 100644
index 0000000..b86cf55
Binary files /dev/null and b/src/src/app/build/intermediates/incremental/debug-mergeNativeLibs/zip-cache/auSv992BISLvLRx5rbvAHX6b4Og= differ
diff --git a/src/src/app/build/intermediates/incremental/debug-mergeNativeLibs/zip-cache/eLKYnIHaM+WGOJhN9g0NTgzDeWQ= b/src/src/app/build/intermediates/incremental/debug-mergeNativeLibs/zip-cache/eLKYnIHaM+WGOJhN9g0NTgzDeWQ=
new file mode 100644
index 0000000..30185e4
Binary files /dev/null and b/src/src/app/build/intermediates/incremental/debug-mergeNativeLibs/zip-cache/eLKYnIHaM+WGOJhN9g0NTgzDeWQ= differ
diff --git a/src/src/app/build/intermediates/incremental/debug-mergeNativeLibs/zip-cache/fEh_8KMJxdQREWeur1Sfdi_W5yc= b/src/src/app/build/intermediates/incremental/debug-mergeNativeLibs/zip-cache/fEh_8KMJxdQREWeur1Sfdi_W5yc=
new file mode 100644
index 0000000..71460a1
Binary files /dev/null and b/src/src/app/build/intermediates/incremental/debug-mergeNativeLibs/zip-cache/fEh_8KMJxdQREWeur1Sfdi_W5yc= differ
diff --git a/src/src/app/build/intermediates/incremental/debug-mergeNativeLibs/zip-cache/gXRoDsR+GuWPJ9bzX6qw4G5SJ2M= b/src/src/app/build/intermediates/incremental/debug-mergeNativeLibs/zip-cache/gXRoDsR+GuWPJ9bzX6qw4G5SJ2M=
new file mode 100644
index 0000000..98ec886
Binary files /dev/null and b/src/src/app/build/intermediates/incremental/debug-mergeNativeLibs/zip-cache/gXRoDsR+GuWPJ9bzX6qw4G5SJ2M= differ
diff --git a/src/src/app/build/intermediates/incremental/debug-mergeNativeLibs/zip-cache/gkStxGAQSDhtyZtix1IZG1zsxDw= b/src/src/app/build/intermediates/incremental/debug-mergeNativeLibs/zip-cache/gkStxGAQSDhtyZtix1IZG1zsxDw=
new file mode 100644
index 0000000..5707aa8
Binary files /dev/null and b/src/src/app/build/intermediates/incremental/debug-mergeNativeLibs/zip-cache/gkStxGAQSDhtyZtix1IZG1zsxDw= differ
diff --git a/src/src/app/build/intermediates/incremental/debug-mergeNativeLibs/zip-cache/lyRVovPySTb7TeFVFnNLaAlpoS4= b/src/src/app/build/intermediates/incremental/debug-mergeNativeLibs/zip-cache/lyRVovPySTb7TeFVFnNLaAlpoS4=
new file mode 100644
index 0000000..144d863
Binary files /dev/null and b/src/src/app/build/intermediates/incremental/debug-mergeNativeLibs/zip-cache/lyRVovPySTb7TeFVFnNLaAlpoS4= differ
diff --git a/src/src/app/build/intermediates/incremental/debug-mergeNativeLibs/zip-cache/nAb55gm3YU81lnP+fvYaYHx6B0M= b/src/src/app/build/intermediates/incremental/debug-mergeNativeLibs/zip-cache/nAb55gm3YU81lnP+fvYaYHx6B0M=
new file mode 100644
index 0000000..d0a17a9
Binary files /dev/null and b/src/src/app/build/intermediates/incremental/debug-mergeNativeLibs/zip-cache/nAb55gm3YU81lnP+fvYaYHx6B0M= differ
diff --git a/src/src/app/build/intermediates/incremental/debug-mergeNativeLibs/zip-cache/ocjNiVEzzEflMVsDyf1gN_b8PSU= b/src/src/app/build/intermediates/incremental/debug-mergeNativeLibs/zip-cache/ocjNiVEzzEflMVsDyf1gN_b8PSU=
new file mode 100644
index 0000000..78ac06c
Binary files /dev/null and b/src/src/app/build/intermediates/incremental/debug-mergeNativeLibs/zip-cache/ocjNiVEzzEflMVsDyf1gN_b8PSU= differ
diff --git a/src/src/app/build/intermediates/incremental/debug-mergeNativeLibs/zip-cache/p7F0a25_zIzPcZpo0DvqEI6SuPA= b/src/src/app/build/intermediates/incremental/debug-mergeNativeLibs/zip-cache/p7F0a25_zIzPcZpo0DvqEI6SuPA=
new file mode 100644
index 0000000..de755d1
Binary files /dev/null and b/src/src/app/build/intermediates/incremental/debug-mergeNativeLibs/zip-cache/p7F0a25_zIzPcZpo0DvqEI6SuPA= differ
diff --git a/src/src/app/build/intermediates/incremental/debug-mergeNativeLibs/zip-cache/qlW4RXtuoAOh8prM7UIbLGg6ra0= b/src/src/app/build/intermediates/incremental/debug-mergeNativeLibs/zip-cache/qlW4RXtuoAOh8prM7UIbLGg6ra0=
new file mode 100644
index 0000000..c3eef53
Binary files /dev/null and b/src/src/app/build/intermediates/incremental/debug-mergeNativeLibs/zip-cache/qlW4RXtuoAOh8prM7UIbLGg6ra0= differ
diff --git a/src/src/app/build/intermediates/incremental/debug-mergeNativeLibs/zip-cache/sG0ONBeGIaJqnbfYbE4esMb9Sso= b/src/src/app/build/intermediates/incremental/debug-mergeNativeLibs/zip-cache/sG0ONBeGIaJqnbfYbE4esMb9Sso=
new file mode 100644
index 0000000..f1f7e72
Binary files /dev/null and b/src/src/app/build/intermediates/incremental/debug-mergeNativeLibs/zip-cache/sG0ONBeGIaJqnbfYbE4esMb9Sso= differ
diff --git a/src/src/app/build/intermediates/incremental/debug-mergeNativeLibs/zip-cache/uPowm7BGJNBEKRUS7A8Ur5AkKHI= b/src/src/app/build/intermediates/incremental/debug-mergeNativeLibs/zip-cache/uPowm7BGJNBEKRUS7A8Ur5AkKHI=
new file mode 100644
index 0000000..22a6ffc
Binary files /dev/null and b/src/src/app/build/intermediates/incremental/debug-mergeNativeLibs/zip-cache/uPowm7BGJNBEKRUS7A8Ur5AkKHI= differ
diff --git a/src/src/app/build/intermediates/incremental/debug-mergeNativeLibs/zip-cache/uU2FTnf3Id0bFvmgrJNqLePreZg= b/src/src/app/build/intermediates/incremental/debug-mergeNativeLibs/zip-cache/uU2FTnf3Id0bFvmgrJNqLePreZg=
new file mode 100644
index 0000000..846dea1
Binary files /dev/null and b/src/src/app/build/intermediates/incremental/debug-mergeNativeLibs/zip-cache/uU2FTnf3Id0bFvmgrJNqLePreZg= differ
diff --git a/src/src/app/build/intermediates/incremental/debug-mergeNativeLibs/zip-cache/w5kxRPvLKqY3B4AS2ZWWVCc4qZE= b/src/src/app/build/intermediates/incremental/debug-mergeNativeLibs/zip-cache/w5kxRPvLKqY3B4AS2ZWWVCc4qZE=
new file mode 100644
index 0000000..124f128
Binary files /dev/null and b/src/src/app/build/intermediates/incremental/debug-mergeNativeLibs/zip-cache/w5kxRPvLKqY3B4AS2ZWWVCc4qZE= differ
diff --git a/src/src/app/build/intermediates/incremental/debug-mergeNativeLibs/zip-cache/wZ8evydlCdpjbmGpUvTZJFomdJU= b/src/src/app/build/intermediates/incremental/debug-mergeNativeLibs/zip-cache/wZ8evydlCdpjbmGpUvTZJFomdJU=
new file mode 100644
index 0000000..189e23f
Binary files /dev/null and b/src/src/app/build/intermediates/incremental/debug-mergeNativeLibs/zip-cache/wZ8evydlCdpjbmGpUvTZJFomdJU= differ
diff --git a/src/src/app/build/intermediates/incremental/mergeDebugAndroidTestResources/compile-file-map.properties b/src/src/app/build/intermediates/incremental/mergeDebugAndroidTestResources/compile-file-map.properties
new file mode 100644
index 0000000..3857b4c
--- /dev/null
+++ b/src/src/app/build/intermediates/incremental/mergeDebugAndroidTestResources/compile-file-map.properties
@@ -0,0 +1 @@
+#Wed Dec 02 13:22:18 CST 2020
diff --git a/src/src/app/build/intermediates/incremental/mergeDebugAndroidTestResources/merger.xml b/src/src/app/build/intermediates/incremental/mergeDebugAndroidTestResources/merger.xml
new file mode 100644
index 0000000..0c486bc
--- /dev/null
+++ b/src/src/app/build/intermediates/incremental/mergeDebugAndroidTestResources/merger.xml
@@ -0,0 +1,2 @@
+
+
\ No newline at end of file
diff --git a/src/src/app/build/intermediates/incremental/mergeDebugAssets/merger.xml b/src/src/app/build/intermediates/incremental/mergeDebugAssets/merger.xml
new file mode 100644
index 0000000..0f55a19
--- /dev/null
+++ b/src/src/app/build/intermediates/incremental/mergeDebugAssets/merger.xml
@@ -0,0 +1,2 @@
+
+
\ No newline at end of file
diff --git a/src/src/app/build/intermediates/incremental/mergeDebugJniLibFolders/merger.xml b/src/src/app/build/intermediates/incremental/mergeDebugJniLibFolders/merger.xml
new file mode 100644
index 0000000..513ea17
--- /dev/null
+++ b/src/src/app/build/intermediates/incremental/mergeDebugJniLibFolders/merger.xml
@@ -0,0 +1,2 @@
+
+
\ No newline at end of file
diff --git a/src/src/app/build/intermediates/incremental/mergeDebugResources/compile-file-map.properties b/src/src/app/build/intermediates/incremental/mergeDebugResources/compile-file-map.properties
new file mode 100644
index 0000000..2a4b3e5
--- /dev/null
+++ b/src/src/app/build/intermediates/incremental/mergeDebugResources/compile-file-map.properties
@@ -0,0 +1,111 @@
+#Thu Feb 25 07:57:59 CST 2021
+E\:\\Note\\src\\app\\src\\main\\res\\xml\\searchable.xml=E\:\\Note\\src\\app\\build\\intermediates\\res\\merged\\debug\\xml_searchable.xml.flat
+E\:\\Note\\src\\app\\src\\main\\res\\layout\\myboard.xml=E\:\\Note\\src\\app\\build\\intermediates\\res\\merged\\debug\\layout_myboard.xml.flat
+E\:\\Note\\src\\app\\src\\main\\res\\drawable-hdpi\\list_yellow_single.9.png=E\:\\Note\\src\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_list_yellow_single.9.png.flat
+E\:\\Note\\src\\app\\src\\main\\res\\drawable-hdpi\\list_white_down.9.png=E\:\\Note\\src\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_list_white_down.9.png.flat
+E\:\\Note\\src\\app\\src\\main\\res\\drawable-hdpi\\list_green_middle.9.png=E\:\\Note\\src\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_list_green_middle.9.png.flat
+E\:\\Note\\src\\app\\src\\main\\res\\menu\\note_list.xml=E\:\\Note\\src\\app\\build\\intermediates\\res\\merged\\debug\\menu_note_list.xml.flat
+E\:\\Note\\src\\app\\src\\main\\res\\drawable-hdpi\\widget_2x_blue.png=E\:\\Note\\src\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_widget_2x_blue.png.flat
+E\:\\Note\\src\\app\\src\\main\\res\\layout\\note_edit.xml=E\:\\Note\\src\\app\\build\\intermediates\\res\\merged\\debug\\layout_note_edit.xml.flat
+E\:\\Note\\src\\app\\src\\main\\res\\drawable-hdpi\\list_blue_up.9.png=E\:\\Note\\src\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_list_blue_up.9.png.flat
+E\:\\Note\\src\\app\\src\\main\\res\\drawable\\new_note.xml=E\:\\Note\\src\\app\\build\\intermediates\\res\\merged\\debug\\drawable_new_note.xml.flat
+E\:\\Note\\src\\app\\src\\main\\res\\drawable-hdpi\\key.png=E\:\\Note\\src\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_key.png.flat
+E\:\\Note\\src\\app\\src\\main\\res\\drawable-hdpi\\list_blue_middle.9.png=E\:\\Note\\src\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_list_blue_middle.9.png.flat
+E\:\\Note\\src\\app\\src\\main\\res\\drawable-hdpi\\title_bar_bg.9.png=E\:\\Note\\src\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_title_bar_bg.9.png.flat
+E\:\\Note\\src\\app\\src\\main\\res\\drawable-hdpi\\bg_btn_set_color.png=E\:\\Note\\src\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_bg_btn_set_color.png.flat
+E\:\\Note\\src\\app\\src\\main\\res\\drawable-hdpi\\search_result.png=E\:\\Note\\src\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_search_result.png.flat
+E\:\\Note\\src\\app\\src\\main\\res\\layout\\settings_header.xml=E\:\\Note\\src\\app\\build\\intermediates\\res\\merged\\debug\\layout_settings_header.xml.flat
+E\:\\Note\\src\\app\\src\\main\\res\\menu\\note_edit.xml=E\:\\Note\\src\\app\\build\\intermediates\\res\\merged\\debug\\menu_note_edit.xml.flat
+E\:\\Note\\src\\app\\src\\main\\res\\drawable-hdpi\\list_yellow_up.9.png=E\:\\Note\\src\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_list_yellow_up.9.png.flat
+E\:\\Note\\src\\app\\src\\main\\res\\drawable-hdpi\\edit_blue.9.png=E\:\\Note\\src\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_edit_blue.9.png.flat
+E\:\\Note\\src\\app\\src\\main\\res\\drawable-hdpi\\widget_2x_white.png=E\:\\Note\\src\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_widget_2x_white.png.flat
+E\:\\Note\\src\\app\\src\\main\\res\\drawable-hdpi\\list_green_single.9.png=E\:\\Note\\src\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_list_green_single.9.png.flat
+E\:\\Note\\src\\app\\src\\main\\res\\drawable-hdpi\\widget_2x_red.png=E\:\\Note\\src\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_widget_2x_red.png.flat
+E\:\\Note\\src\\app\\src\\main\\res\\raw-zh-rCN\\contact.txt=E\:\\Note\\src\\app\\build\\intermediates\\res\\merged\\debug\\raw-zh-rCN_contact.txt.flat
+E\:\\Note\\src\\app\\src\\main\\res\\menu\\sub_folder.xml=E\:\\Note\\src\\app\\build\\intermediates\\res\\merged\\debug\\menu_sub_folder.xml.flat
+E\:\\Note\\src\\app\\src\\main\\res\\drawable-hdpi\\list_green_up.9.png=E\:\\Note\\src\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_list_green_up.9.png.flat
+E\:\\Note\\src\\app\\src\\main\\res\\drawable-hdpi\\list_blue_single.9.png=E\:\\Note\\src\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_list_blue_single.9.png.flat
+E\:\\Note\\src\\app\\src\\main\\res\\layout\\folder_list_item.xml=E\:\\Note\\src\\app\\build\\intermediates\\res\\merged\\debug\\layout_folder_list_item.xml.flat
+E\:\\Note\\src\\app\\src\\main\\res\\drawable-hdpi\\edit_title_yellow.9.png=E\:\\Note\\src\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_edit_title_yellow.9.png.flat
+E\:\\Note\\src\\app\\src\\main\\res\\drawable-hdpi\\clock.png=E\:\\Note\\src\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_clock.png.flat
+E\:\\Note\\src\\app\\src\\main\\res\\drawable-hdpi\\edit_green.9.png=E\:\\Note\\src\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_edit_green.9.png.flat
+E\:\\Note\\src\\app\\src\\main\\res\\drawable-hdpi\\edit_title_white.9.png=E\:\\Note\\src\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_edit_title_white.9.png.flat
+E\:\\Note\\src\\app\\src\\main\\res\\layout\\datetime_picker.xml=E\:\\Note\\src\\app\\build\\intermediates\\res\\merged\\debug\\layout_datetime_picker.xml.flat
+E\:\\Note\\src\\app\\src\\main\\res\\drawable-hdpi\\list_background.png=E\:\\Note\\src\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_list_background.png.flat
+E\:\\Note\\src\\app\\src\\main\\res\\raw-zh-rCN\\introduction=E\:\\Note\\src\\app\\build\\intermediates\\res\\merged\\debug\\raw-zh-rCN_introduction.flat
+E\:\\Note\\src\\app\\src\\main\\res\\raw\\gestures.txt=E\:\\Note\\src\\app\\build\\intermediates\\res\\merged\\debug\\raw_gestures.txt.flat
+E\:\\Note\\src\\app\\src\\main\\res\\drawable-hdpi\\icon_app.png=E\:\\Note\\src\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_icon_app.png.flat
+E\:\\Note\\src\\app\\src\\main\\res\\drawable-hdpi\\font_size_selector_bg.9.png=E\:\\Note\\src\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_font_size_selector_bg.9.png.flat
+E\:\\Note\\src\\app\\src\\main\\res\\drawable-hdpi\\new_note_pressed.png=E\:\\Note\\src\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_new_note_pressed.png.flat
+E\:\\Note\\src\\app\\src\\main\\res\\layout\\account_dialog_title.xml=E\:\\Note\\src\\app\\build\\intermediates\\res\\merged\\debug\\layout_account_dialog_title.xml.flat
+E\:\\Note\\src\\app\\src\\main\\res\\drawable-hdpi\\widget_4x_red.png=E\:\\Note\\src\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_widget_4x_red.png.flat
+E\:\\Note\\src\\app\\src\\main\\res\\menu\\call_note_edit.xml=E\:\\Note\\src\\app\\build\\intermediates\\res\\merged\\debug\\menu_call_note_edit.xml.flat
+E\:\\Note\\src\\app\\src\\main\\res\\drawable-hdpi\\call_record.png=E\:\\Note\\src\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_call_record.png.flat
+E\:\\Note\\src\\app\\src\\main\\res\\drawable-hdpi\\list_white_up.9.png=E\:\\Note\\src\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_list_white_up.9.png.flat
+E\:\\Note\\src\\app\\src\\main\\res\\layout\\note_list_dropdown_menu.xml=E\:\\Note\\src\\app\\build\\intermediates\\res\\merged\\debug\\layout_note_list_dropdown_menu.xml.flat
+E\:\\Note\\src\\app\\src\\main\\res\\drawable-hdpi\\title_alert.png=E\:\\Note\\src\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_title_alert.png.flat
+E\:\\Note\\src\\app\\src\\main\\res\\drawable-hdpi\\edit_yellow.9.png=E\:\\Note\\src\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_edit_yellow.9.png.flat
+E\:\\Note\\src\\app\\src\\main\\res\\menu\\note_list_options.xml=E\:\\Note\\src\\app\\build\\intermediates\\res\\merged\\debug\\menu_note_list_options.xml.flat
+E\:\\Note\\src\\app\\src\\main\\res\\drawable-hdpi\\note_edit_color_selector_panel.png=E\:\\Note\\src\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_note_edit_color_selector_panel.png.flat
+E\:\\Note\\src\\app\\src\\main\\res\\layout\\dialog_pwd.xml=E\:\\Note\\src\\app\\build\\intermediates\\res\\merged\\debug\\layout_dialog_pwd.xml.flat
+E\:\\Note\\src\\app\\src\\main\\res\\raw-zh-rCN\\event.txt=E\:\\Note\\src\\app\\build\\intermediates\\res\\merged\\debug\\raw-zh-rCN_event.txt.flat
+E\:\\Note\\src\\app\\src\\main\\res\\layout\\dialog_pwd_confirm.xml=E\:\\Note\\src\\app\\build\\intermediates\\res\\merged\\debug\\layout_dialog_pwd_confirm.xml.flat
+E\:\\Note\\src\\app\\src\\main\\res\\drawable-hdpi\\widget_4x_green.png=E\:\\Note\\src\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_widget_4x_green.png.flat
+E\:\\Note\\src\\app\\src\\main\\res\\drawable-hdpi\\edit_red.9.png=E\:\\Note\\src\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_edit_red.9.png.flat
+E\:\\Note\\src\\app\\src\\main\\res\\layout\\widget_2x.xml=E\:\\Note\\src\\app\\build\\intermediates\\res\\merged\\debug\\layout_widget_2x.xml.flat
+E\:\\Note\\src\\app\\src\\main\\res\\drawable-hdpi\\bg_color_btn_mask.png=E\:\\Note\\src\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_bg_color_btn_mask.png.flat
+E\:\\Note\\src\\app\\src\\main\\res\\drawable-hdpi\\list_folder.9.png=E\:\\Note\\src\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_list_folder.9.png.flat
+E\:\\Note\\src\\app\\src\\main\\res\\raw\\contact.txt=E\:\\Note\\src\\app\\build\\intermediates\\res\\merged\\debug\\raw_contact.txt.flat
+E\:\\Note\\src\\app\\src\\main\\res\\layout\\add_account_text.xml=E\:\\Note\\src\\app\\build\\intermediates\\res\\merged\\debug\\layout_add_account_text.xml.flat
+E\:\\Note\\src\\app\\src\\main\\res\\drawable-hdpi\\list_green_down.9.png=E\:\\Note\\src\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_list_green_down.9.png.flat
+E\:\\Note\\src\\app\\src\\main\\res\\drawable-hdpi\\notification.png=E\:\\Note\\src\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_notification.png.flat
+E\:\\Note\\src\\app\\src\\main\\res\\drawable-hdpi\\menu_delete.png=E\:\\Note\\src\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_menu_delete.png.flat
+E\:\\Note\\src\\app\\src\\main\\res\\drawable-hdpi\\new_note_normal.png=E\:\\Note\\src\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_new_note_normal.png.flat
+E\:\\Note\\src\\app\\src\\main\\res\\drawable-hdpi\\font_large.png=E\:\\Note\\src\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_font_large.png.flat
+E\:\\Note\\src\\app\\src\\main\\res\\menu\\note_list_dropdown.xml=E\:\\Note\\src\\app\\build\\intermediates\\res\\merged\\debug\\menu_note_list_dropdown.xml.flat
+E\:\\Note\\src\\app\\src\\main\\res\\drawable-hdpi\\widget_4x_yellow.png=E\:\\Note\\src\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_widget_4x_yellow.png.flat
+E\:\\Note\\src\\app\\src\\main\\res\\color\\secondary_text_dark.xml=E\:\\Note\\src\\app\\build\\intermediates\\res\\merged\\debug\\color_secondary_text_dark.xml.flat
+E\:\\Note\\src\\app\\src\\main\\res\\drawable-hdpi\\list_red_up.9.png=E\:\\Note\\src\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_list_red_up.9.png.flat
+E\:\\Note\\src\\app\\src\\main\\res\\drawable-hdpi\\list_yellow_down.9.png=E\:\\Note\\src\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_list_yellow_down.9.png.flat
+E\:\\Note\\src\\app\\src\\main\\res\\drawable-hdpi\\list_blue_down.9.png=E\:\\Note\\src\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_list_blue_down.9.png.flat
+E\:\\Note\\src\\app\\src\\main\\res\\color\\primary_text_dark.xml=E\:\\Note\\src\\app\\build\\intermediates\\res\\merged\\debug\\color_primary_text_dark.xml.flat
+E\:\\Note\\src\\app\\src\\main\\res\\drawable-hdpi\\widget_4x_white.png=E\:\\Note\\src\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_widget_4x_white.png.flat
+E\:\\Note\\src\\app\\src\\main\\res\\drawable-hdpi\\widget_2x_yellow.png=E\:\\Note\\src\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_widget_2x_yellow.png.flat
+E\:\\Note\\src\\app\\src\\main\\res\\drawable-hdpi\\list_white_middle.9.png=E\:\\Note\\src\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_list_white_middle.9.png.flat
+E\:\\Note\\src\\app\\src\\main\\res\\drawable-hdpi\\font_super.png=E\:\\Note\\src\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_font_super.png.flat
+E\:\\Note\\src\\app\\src\\main\\res\\drawable-hdpi\\edit_white.9.png=E\:\\Note\\src\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_edit_white.9.png.flat
+E\:\\Note\\src\\app\\src\\main\\res\\layout\\dialog_save.xml=E\:\\Note\\src\\app\\build\\intermediates\\res\\merged\\debug\\layout_dialog_save.xml.flat
+E\:\\Note\\src\\app\\src\\main\\res\\drawable-hdpi\\selected.png=E\:\\Note\\src\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_selected.png.flat
+E\:\\Note\\src\\app\\src\\main\\res\\drawable-hdpi\\list_red_middle.9.png=E\:\\Note\\src\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_list_red_middle.9.png.flat
+E\:\\Note\\src\\app\\src\\main\\res\\xml\\preferences.xml=E\:\\Note\\src\\app\\build\\intermediates\\res\\merged\\debug\\xml_preferences.xml.flat
+E\:\\Note\\src\\app\\src\\main\\res\\drawable-hdpi\\dropdown_icon.9.png=E\:\\Note\\src\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_dropdown_icon.9.png.flat
+E\:\\Note\\src\\app\\src\\main\\res\\layout\\note_item.xml=E\:\\Note\\src\\app\\build\\intermediates\\res\\merged\\debug\\layout_note_item.xml.flat
+E\:\\Note\\src\\app\\src\\main\\res\\drawable-hdpi\\edit_title_blue.9.png=E\:\\Note\\src\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_edit_title_blue.9.png.flat
+E\:\\Note\\src\\app\\src\\main\\res\\drawable-hdpi\\list_white_single.9.png=E\:\\Note\\src\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_list_white_single.9.png.flat
+E\:\\Note\\src\\app\\src\\main\\res\\drawable-hdpi\\huaban.PNG=E\:\\Note\\src\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_huaban.PNG.flat
+E\:\\Note\\src\\app\\src\\main\\res\\raw\\passwd.txt=E\:\\Note\\src\\app\\build\\intermediates\\res\\merged\\debug\\raw_passwd.txt.flat
+E\:\\Note\\src\\app\\src\\main\\res\\xml\\widget_4x_info.xml=E\:\\Note\\src\\app\\build\\intermediates\\res\\merged\\debug\\xml_widget_4x_info.xml.flat
+E\:\\Note\\src\\app\\src\\main\\res\\raw\\introduction=E\:\\Note\\src\\app\\build\\intermediates\\res\\merged\\debug\\raw_introduction.flat
+E\:\\Note\\src\\app\\src\\main\\res\\layout\\note_edit_list_item.xml=E\:\\Note\\src\\app\\build\\intermediates\\res\\merged\\debug\\layout_note_edit_list_item.xml.flat
+E\:\\Note\\src\\app\\src\\main\\res\\layout\\widget_4x.xml=E\:\\Note\\src\\app\\build\\intermediates\\res\\merged\\debug\\layout_widget_4x.xml.flat
+E\:\\Note\\src\\app\\src\\main\\res\\drawable-hdpi\\edit_title_green.9.png=E\:\\Note\\src\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_edit_title_green.9.png.flat
+E\:\\Note\\src\\app\\src\\main\\res\\drawable-hdpi\\list_red_down.9.png=E\:\\Note\\src\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_list_red_down.9.png.flat
+E\:\\Note\\src\\app\\src\\main\\res\\drawable-hdpi\\list_red_single.9.png=E\:\\Note\\src\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_list_red_single.9.png.flat
+E\:\\Note\\src\\app\\src\\main\\res\\drawable-hdpi\\menu_move.png=E\:\\Note\\src\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_menu_move.png.flat
+E\:\\Note\\src\\app\\src\\main\\res\\raw\\event.txt=E\:\\Note\\src\\app\\build\\intermediates\\res\\merged\\debug\\raw_event.txt.flat
+E\:\\Note\\src\\app\\src\\main\\res\\raw-zh-rCN\\gestures.txt=E\:\\Note\\src\\app\\build\\intermediates\\res\\merged\\debug\\raw-zh-rCN_gestures.txt.flat
+E\:\\Note\\src\\app\\src\\main\\res\\drawable-hdpi\\widget_4x_blue.png=E\:\\Note\\src\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_widget_4x_blue.png.flat
+E\:\\Note\\src\\app\\src\\main\\res\\drawable-hdpi\\font_small.png=E\:\\Note\\src\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_font_small.png.flat
+E\:\\Note\\src\\app\\src\\main\\res\\drawable-hdpi\\list_yellow_middle.9.png=E\:\\Note\\src\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_list_yellow_middle.9.png.flat
+E\:\\Note\\src\\app\\src\\main\\res\\menu\\call_record_folder.xml=E\:\\Note\\src\\app\\build\\intermediates\\res\\merged\\debug\\menu_call_record_folder.xml.flat
+E\:\\Note\\src\\app\\src\\main\\res\\drawable-hdpi\\font_normal.png=E\:\\Note\\src\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_font_normal.png.flat
+E\:\\Note\\src\\app\\src\\main\\res\\layout\\dialog_edit_text.xml=E\:\\Note\\src\\app\\build\\intermediates\\res\\merged\\debug\\layout_dialog_edit_text.xml.flat
+E\:\\Note\\src\\app\\src\\main\\res\\drawable-hdpi\\delete.png=E\:\\Note\\src\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_delete.png.flat
+E\:\\Note\\src\\app\\src\\main\\res\\xml\\widget_2x_info.xml=E\:\\Note\\src\\app\\build\\intermediates\\res\\merged\\debug\\xml_widget_2x_info.xml.flat
+E\:\\Note\\src\\app\\src\\main\\res\\drawable-hdpi\\edit_title_red.9.png=E\:\\Note\\src\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_edit_title_red.9.png.flat
+E\:\\Note\\src\\app\\src\\main\\res\\drawable-hdpi\\widget_2x_green.png=E\:\\Note\\src\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_widget_2x_green.png.flat
+E\:\\Note\\src\\app\\src\\main\\res\\drawable-hdpi\\list_footer_bg.9.png=E\:\\Note\\src\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_list_footer_bg.9.png.flat
+E\:\\Note\\src\\app\\src\\main\\res\\layout\\note_list_footer.xml=E\:\\Note\\src\\app\\build\\intermediates\\res\\merged\\debug\\layout_note_list_footer.xml.flat
+E\:\\Note\\src\\app\\src\\main\\res\\layout\\note_list.xml=E\:\\Note\\src\\app\\build\\intermediates\\res\\merged\\debug\\layout_note_list.xml.flat
+E\:\\Note\\src\\app\\src\\main\\res\\layout\\gesture_setting.xml=E\:\\Note\\src\\app\\build\\intermediates\\res\\merged\\debug\\layout_gesture_setting.xml.flat
+E\:\\Note\\src\\app\\src\\main\\res\\raw-zh-rCN\\passwd.txt=E\:\\Note\\src\\app\\build\\intermediates\\res\\merged\\debug\\raw-zh-rCN_passwd.txt.flat
diff --git a/src/src/app/build/intermediates/incremental/mergeDebugResources/merged.dir/values-af/values-af.xml b/src/src/app/build/intermediates/incremental/mergeDebugResources/merged.dir/values-af/values-af.xml
new file mode 100644
index 0000000..d8fe69b
--- /dev/null
+++ b/src/src/app/build/intermediates/incremental/mergeDebugResources/merged.dir/values-af/values-af.xml
@@ -0,0 +1,32 @@
+
+
+ "Navigeer tuis"
+ "Navigeer op"
+ "Nog opsies"
+ "Klaar"
+ "Sien alles"
+ "Kies \'n program"
+ "AF"
+ "AAN"
+ "Alt+"
+ "Ctrl+"
+ "delete"
+ "enter"
+ "Funksie+"
+ "Meta+"
+ "Shift+"
+ "spasiebalk"
+ "Simbool+"
+ "Kieslys+"
+ "Soek …"
+ "Vee navraag uit"
+ "Soeknavraag"
+ "Soek"
+ "Dien navraag in"
+ "Stemsoektog"
+ "Deel met"
+ "Deel met %s"
+ "Vou in"
+ "Soek"
+ "999+"
+
\ No newline at end of file
diff --git a/src/src/app/build/intermediates/incremental/mergeDebugResources/merged.dir/values-am/values-am.xml b/src/src/app/build/intermediates/incremental/mergeDebugResources/merged.dir/values-am/values-am.xml
new file mode 100644
index 0000000..1029135
--- /dev/null
+++ b/src/src/app/build/intermediates/incremental/mergeDebugResources/merged.dir/values-am/values-am.xml
@@ -0,0 +1,32 @@
+
+
+ "ወደ መነሻ ይዳስሱ"
+ "ወደ ላይ ይዳስሱ"
+ "ተጨማሪ አማራጮች"
+ "ተከናውኗል"
+ "ሁሉንም ይመልከቱ"
+ "መተግበሪያ ይምረጡ"
+ "ጠፍቷል"
+ "በርቷል"
+ "Alt+"
+ "Ctrl+"
+ "ሰርዝ"
+ "enter"
+ "Function+"
+ "Meta+"
+ "Shift+"
+ "space"
+ "Sym+"
+ "ምናሌ+"
+ "ፈልግ…"
+ "መጠይቅ አጽዳ"
+ "የፍለጋ ጥያቄ"
+ "ፍለጋ"
+ "መጠይቅ ያስረክቡ"
+ "የድምፅ ፍለጋ"
+ "ከሚከተለው ጋር ያጋሩ"
+ "ከ%s ጋር አጋራ"
+ "ሰብስብ"
+ "ፈልግ"
+ "999+"
+
\ No newline at end of file
diff --git a/src/src/app/build/intermediates/incremental/mergeDebugResources/merged.dir/values-ar/values-ar.xml b/src/src/app/build/intermediates/incremental/mergeDebugResources/merged.dir/values-ar/values-ar.xml
new file mode 100644
index 0000000..e7fb419
--- /dev/null
+++ b/src/src/app/build/intermediates/incremental/mergeDebugResources/merged.dir/values-ar/values-ar.xml
@@ -0,0 +1,32 @@
+
+
+ "التنقل إلى الشاشة الرئيسية"
+ "التنقل إلى أعلى"
+ "خيارات إضافية"
+ "تم"
+ "عرض الكل"
+ "اختيار تطبيق"
+ "إيقاف"
+ "تشغيل"
+ "Alt+"
+ "Ctrl+"
+ "delete"
+ "enter"
+ "Function+"
+ "Meta+"
+ "Shift+"
+ "space"
+ "Sym+"
+ "القائمة+"
+ "بحث…"
+ "محو طلب البحث"
+ "طلب البحث"
+ "بحث"
+ "إرسال طلب البحث"
+ "البحث الصوتي"
+ "مشاركة مع"
+ "مشاركة مع %s"
+ "تصغير"
+ "البحث"
+ "999+"
+
\ No newline at end of file
diff --git a/src/src/app/build/intermediates/incremental/mergeDebugResources/merged.dir/values-as/values-as.xml b/src/src/app/build/intermediates/incremental/mergeDebugResources/merged.dir/values-as/values-as.xml
new file mode 100644
index 0000000..2287e53
--- /dev/null
+++ b/src/src/app/build/intermediates/incremental/mergeDebugResources/merged.dir/values-as/values-as.xml
@@ -0,0 +1,32 @@
+
+
+ "গৃহ পৃষ্ঠালৈ যাওক"
+ "ওপৰলৈ যাওক"
+ "অধিক বিকল্প"
+ "সম্পন্ন কৰা হ\'ল"
+ "সকলো চাওক"
+ "এটা এপ্ বাছনি কৰক"
+ "অফ কৰক"
+ "অন কৰক"
+ "Alt+"
+ "CTRL+"
+ "মচক"
+ "এণ্টাৰ"
+ "ফাংশ্বন+"
+ "মেটা+"
+ "শ্বিফ্ট+"
+ "স্পেচ"
+ "Sym+"
+ "মেনু+"
+ "অনুসন্ধান কৰক…"
+ "প্ৰশ্ন মচক"
+ "সন্ধান কৰিব খোজা প্ৰশ্ন"
+ "সন্ধান কৰক"
+ "প্ৰশ্ন দাখিল কৰক"
+ "কণ্ঠধ্বনিৰ যোগেৰে সন্ধান কৰক"
+ "ইয়াৰ জৰিয়তে শ্বেয়াৰ কৰক"
+ "%sৰ জৰিয়তে শ্বেয়াৰ কৰক"
+ "সংকুচিত কৰক"
+ "অনুসন্ধান কৰক"
+ "৯৯৯+"
+
\ No newline at end of file
diff --git a/src/src/app/build/intermediates/incremental/mergeDebugResources/merged.dir/values-az/values-az.xml b/src/src/app/build/intermediates/incremental/mergeDebugResources/merged.dir/values-az/values-az.xml
new file mode 100644
index 0000000..8bbbd5b
--- /dev/null
+++ b/src/src/app/build/intermediates/incremental/mergeDebugResources/merged.dir/values-az/values-az.xml
@@ -0,0 +1,32 @@
+
+
+ "Evə naviqasiya et"
+ "Yuxarı get"
+ "Digər variantlar"
+ "Hazırdır"
+ "Hamısına baxın"
+ "Tətbiq seçin"
+ "DEAKTİV"
+ "AKTİV"
+ "Alt+"
+ "Ctrl+"
+ "silin"
+ "daxil olun"
+ "Funksiya+"
+ "Meta+"
+ "Shift+"
+ "kosmos"
+ "Sym+"
+ "Menyu+"
+ "Axtarış..."
+ "Sorğunu təmizlə"
+ "Axtarış sorğusu"
+ "Axtarış"
+ "Sorğunu göndərin"
+ "Səsli axtarış"
+ "Bununla paylaşın"
+ "%s ilə paylaşın"
+ "Yığışdırın"
+ "Axtarış"
+ "999+"
+
\ No newline at end of file
diff --git a/src/src/app/build/intermediates/incremental/mergeDebugResources/merged.dir/values-b+sr+Latn/values-b+sr+Latn.xml b/src/src/app/build/intermediates/incremental/mergeDebugResources/merged.dir/values-b+sr+Latn/values-b+sr+Latn.xml
new file mode 100644
index 0000000..77f07c2
--- /dev/null
+++ b/src/src/app/build/intermediates/incremental/mergeDebugResources/merged.dir/values-b+sr+Latn/values-b+sr+Latn.xml
@@ -0,0 +1,32 @@
+
+
+ "Odlazak na Početnu"
+ "Kretanje nagore"
+ "Još opcija"
+ "Gotovo"
+ "Prikaži sve"
+ "Izbor aplikacije"
+ "ISKLJUČI"
+ "UKLJUČI"
+ "Alt+"
+ "Ctrl+"
+ "delete"
+ "enter"
+ "Function+"
+ "Meta+"
+ "Shift+"
+ "taster za razmak"
+ "Sym+"
+ "Menu+"
+ "Pretražite..."
+ "Brisanje upita"
+ "Upit za pretragu"
+ "Pretraga"
+ "Slanje upita"
+ "Glasovna pretraga"
+ "Deli sa"
+ "Deljenje sa aplikacijom %s"
+ "Skupi"
+ "Pretraži"
+ "999+"
+
\ No newline at end of file
diff --git a/src/src/app/build/intermediates/incremental/mergeDebugResources/merged.dir/values-be/values-be.xml b/src/src/app/build/intermediates/incremental/mergeDebugResources/merged.dir/values-be/values-be.xml
new file mode 100644
index 0000000..a0019be
--- /dev/null
+++ b/src/src/app/build/intermediates/incremental/mergeDebugResources/merged.dir/values-be/values-be.xml
@@ -0,0 +1,32 @@
+
+
+ "Перайсці на галоўную старонку"
+ "Перайсці ўверх"
+ "Дадатковыя параметры"
+ "Гатова"
+ "Прагледзець усё"
+ "Выбраць праграму"
+ "ВЫКЛ."
+ "УКЛ."
+ "Alt +"
+ "Ctrl +"
+ "Delete"
+ "Enter"
+ "Fn +"
+ "Meta +"
+ "Shift +"
+ "Прабел"
+ "Sym +"
+ "Меню +"
+ "Пошук..."
+ "Выдалiць запыт"
+ "Запыт на пошук"
+ "Пошук"
+ "Адправіць запыт"
+ "Галасавы пошук"
+ "Абагуліць з"
+ "Абагуліць праз праграму %s"
+ "Згарнуць"
+ "Пошук"
+ "999+"
+
\ No newline at end of file
diff --git a/src/src/app/build/intermediates/incremental/mergeDebugResources/merged.dir/values-bg/values-bg.xml b/src/src/app/build/intermediates/incremental/mergeDebugResources/merged.dir/values-bg/values-bg.xml
new file mode 100644
index 0000000..ce1cb44
--- /dev/null
+++ b/src/src/app/build/intermediates/incremental/mergeDebugResources/merged.dir/values-bg/values-bg.xml
@@ -0,0 +1,32 @@
+
+
+ "Придвижване към „Начало“"
+ "Придвижване нагоре"
+ "Още опции"
+ "Готово"
+ "Вижте всички"
+ "Изберете приложение"
+ "ИЗКЛ."
+ "ВКЛ."
+ "Alt+"
+ "Ctrl+"
+ "delete"
+ "enter"
+ "Function+"
+ "Meta+"
+ "Shift+"
+ "клавиша за интервал"
+ "Sym+"
+ "Menu+"
+ "Търсете…"
+ "Изчистване на заявката"
+ "Заявка за търсене"
+ "Търсене"
+ "Изпращане на заявката"
+ "Гласово търсене"
+ "Споделяне със:"
+ "Споделяне със: %s"
+ "Свиване"
+ "Търсене"
+ "999+"
+
\ No newline at end of file
diff --git a/src/src/app/build/intermediates/incremental/mergeDebugResources/merged.dir/values-bn/values-bn.xml b/src/src/app/build/intermediates/incremental/mergeDebugResources/merged.dir/values-bn/values-bn.xml
new file mode 100644
index 0000000..b9e182a
--- /dev/null
+++ b/src/src/app/build/intermediates/incremental/mergeDebugResources/merged.dir/values-bn/values-bn.xml
@@ -0,0 +1,32 @@
+
+
+ "হোম এ নেভিগেট করুন"
+ "উপরের দিকে নেভিগেট করুন"
+ "আরও বিকল্প"
+ "সম্পন্ন হয়েছে"
+ "সবগুলো দেখুন"
+ "একটি অ্যাপ্লিকেশান বেছে নিন"
+ "বন্ধ"
+ "চালু"
+ "Alt+"
+ "Ctrl+"
+ "মুছুন"
+ "enter"
+ "Function+"
+ "Meta+"
+ "Shift+"
+ "স্পেস"
+ "Sym+"
+ "মেনু+"
+ "অনুসন্ধান..."
+ "ক্যোয়ারী সাফ করুন"
+ "ক্যোয়ারী খুঁজুন"
+ "খুঁজুন"
+ "ক্যোয়ারী জমা দিন"
+ "ভয়েস অনুসন্ধান"
+ "এর সাথে শেয়ার করুন"
+ "%s এর সাথে শেয়ার করুন"
+ "সঙ্কুচিত করুন"
+ "খুঁজুন"
+ "৯৯৯+"
+
\ No newline at end of file
diff --git a/src/src/app/build/intermediates/incremental/mergeDebugResources/merged.dir/values-bs/values-bs.xml b/src/src/app/build/intermediates/incremental/mergeDebugResources/merged.dir/values-bs/values-bs.xml
new file mode 100644
index 0000000..bc8630d
--- /dev/null
+++ b/src/src/app/build/intermediates/incremental/mergeDebugResources/merged.dir/values-bs/values-bs.xml
@@ -0,0 +1,32 @@
+
+
+ "Vrati se na početnu stranicu"
+ "Navigiraj prema gore"
+ "Više opcija"
+ "Gotovo"
+ "Prikaži sve"
+ "Odaberite aplikaciju"
+ "ISKLJUČI"
+ "UKLJUČI"
+ "Alt+"
+ "Ctrl+"
+ "delete"
+ "enter"
+ "Function+"
+ "Meta+"
+ "Shift+"
+ "razmaknica"
+ "Sym+"
+ "Menu+"
+ "Pretraži..."
+ "Obriši upit"
+ "Pretraži upit"
+ "Traži"
+ "Pošalji upit"
+ "Glasovno pretraživanje"
+ "Dijeli sa"
+ "Dijeli koristeći aplikaciju %s"
+ "Skupi"
+ "Pretraži"
+ "999+"
+
\ No newline at end of file
diff --git a/src/src/app/build/intermediates/incremental/mergeDebugResources/merged.dir/values-ca/values-ca.xml b/src/src/app/build/intermediates/incremental/mergeDebugResources/merged.dir/values-ca/values-ca.xml
new file mode 100644
index 0000000..833039e
--- /dev/null
+++ b/src/src/app/build/intermediates/incremental/mergeDebugResources/merged.dir/values-ca/values-ca.xml
@@ -0,0 +1,32 @@
+
+
+ "Navega a la pàgina d\'inici"
+ "Navega cap a dalt"
+ "Més opcions"
+ "Fet"
+ "Mostra\'ls tots"
+ "Selecciona una aplicació"
+ "DESACTIVAT"
+ "ACTIVAT"
+ "Alt+"
+ "Ctrl+"
+ "Supr"
+ "Retorn"
+ "Funció+"
+ "Meta+"
+ "Maj+"
+ "Espai"
+ "Sym+"
+ "Menú+"
+ "Cerca..."
+ "Esborra la consulta"
+ "Consulta de cerca"
+ "Cerca"
+ "Envia la consulta"
+ "Cerca per veu"
+ "Comparteix amb"
+ "Comparteix amb %s"
+ "Replega"
+ "Cerca"
+ "999+"
+
\ No newline at end of file
diff --git a/src/src/app/build/intermediates/incremental/mergeDebugResources/merged.dir/values-cs/values-cs.xml b/src/src/app/build/intermediates/incremental/mergeDebugResources/merged.dir/values-cs/values-cs.xml
new file mode 100644
index 0000000..a5878ca
--- /dev/null
+++ b/src/src/app/build/intermediates/incremental/mergeDebugResources/merged.dir/values-cs/values-cs.xml
@@ -0,0 +1,32 @@
+
+
+ "Přejít na plochu"
+ "Přejít nahoru"
+ "Více možností"
+ "Hotovo"
+ "Zobrazit vše"
+ "Vybrat aplikaci"
+ "VYPNUTO"
+ "ZAPNUTO"
+ "Alt+"
+ "Ctrl+"
+ "delete"
+ "enter"
+ "Fn+"
+ "Meta+"
+ "Shift+"
+ "mezerník"
+ "Sym+"
+ "Menu+"
+ "Vyhledat…"
+ "Smazat dotaz"
+ "Vyhledávací dotaz"
+ "Hledat"
+ "Odeslat dotaz"
+ "Hlasové vyhledávání"
+ "Sdílet pomocí"
+ "Sdílet s aplikací %s"
+ "Sbalit"
+ "Hledat"
+ "999+"
+
\ No newline at end of file
diff --git a/src/src/app/build/intermediates/incremental/mergeDebugResources/merged.dir/values-da/values-da.xml b/src/src/app/build/intermediates/incremental/mergeDebugResources/merged.dir/values-da/values-da.xml
new file mode 100644
index 0000000..7ae28b4
--- /dev/null
+++ b/src/src/app/build/intermediates/incremental/mergeDebugResources/merged.dir/values-da/values-da.xml
@@ -0,0 +1,32 @@
+
+
+ "Naviger hjem"
+ "Naviger op"
+ "Flere muligheder"
+ "Luk"
+ "Se alle"
+ "Vælg en app"
+ "FRA"
+ "TIL"
+ "Alt+"
+ "Ctrl+"
+ "delete"
+ "enter"
+ "Fn+"
+ "Meta+"
+ "Shift+"
+ "mellemrum"
+ "Sym+"
+ "Menu+"
+ "Søg…"
+ "Ryd forespørgslen"
+ "Søgeforespørgsel"
+ "Søg"
+ "Indsend forespørgslen"
+ "Talesøgning"
+ "Del med"
+ "Del med %s"
+ "Skjul"
+ "Søg"
+ "999+"
+
\ No newline at end of file
diff --git a/src/src/app/build/intermediates/incremental/mergeDebugResources/merged.dir/values-de/values-de.xml b/src/src/app/build/intermediates/incremental/mergeDebugResources/merged.dir/values-de/values-de.xml
new file mode 100644
index 0000000..d2f8510
--- /dev/null
+++ b/src/src/app/build/intermediates/incremental/mergeDebugResources/merged.dir/values-de/values-de.xml
@@ -0,0 +1,32 @@
+
+
+ "Zur Startseite"
+ "Nach oben"
+ "Weitere Optionen"
+ "Fertig"
+ "Alle ansehen"
+ "App auswählen"
+ "Aus"
+ "An"
+ "Alt +"
+ "Strg +"
+ "Löschen"
+ "Eingabetaste"
+ "Funktionstaste +"
+ "Meta-Taste +"
+ "Umschalttaste +"
+ "Leertaste +"
+ "Sym-Taste +"
+ "Menütaste +"
+ "Suchen…"
+ "Suchanfrage löschen"
+ "Suchanfrage"
+ "Suchen"
+ "Suchanfrage senden"
+ "Sprachsuche"
+ "Freigeben für"
+ "Mit %s teilen"
+ "Minimieren"
+ "Suchen"
+ "999+"
+
\ No newline at end of file
diff --git a/src/src/app/build/intermediates/incremental/mergeDebugResources/merged.dir/values-el/values-el.xml b/src/src/app/build/intermediates/incremental/mergeDebugResources/merged.dir/values-el/values-el.xml
new file mode 100644
index 0000000..de7398c
--- /dev/null
+++ b/src/src/app/build/intermediates/incremental/mergeDebugResources/merged.dir/values-el/values-el.xml
@@ -0,0 +1,32 @@
+
+
+ "Πλοήγηση στην αρχική σελίδα"
+ "Πλοήγηση προς τα επάνω"
+ "Περισσότερες επιλογές"
+ "Τέλος"
+ "Προβολή όλων"
+ "Επιλέξτε κάποια εφαρμογή"
+ "ΑΠΕΝΕΡΓΟΠΟΙΗΣΗ"
+ "ΕΝΕΡΓΟΠΟΙΗΣΗ"
+ "Alt+"
+ "Ctrl+"
+ "delete"
+ "enter"
+ "Function+"
+ "Meta+"
+ "Shift+"
+ "διάστημα"
+ "Sym+"
+ "Menu+"
+ "Αναζήτηση…"
+ "Διαγραφή ερωτήματος"
+ "Ερώτημα αναζήτησης"
+ "Αναζήτηση"
+ "Υποβολή ερωτήματος"
+ "Φωνητική αναζήτηση"
+ "Κοινή χρήση με"
+ "Κοινή χρήση με %s"
+ "Σύμπτυξη"
+ "Αναζήτηση"
+ "999+"
+
\ No newline at end of file
diff --git a/src/src/app/build/intermediates/incremental/mergeDebugResources/merged.dir/values-en-rAU/values-en-rAU.xml b/src/src/app/build/intermediates/incremental/mergeDebugResources/merged.dir/values-en-rAU/values-en-rAU.xml
new file mode 100644
index 0000000..0b21ff7
--- /dev/null
+++ b/src/src/app/build/intermediates/incremental/mergeDebugResources/merged.dir/values-en-rAU/values-en-rAU.xml
@@ -0,0 +1,32 @@
+
+
+ "Navigate home"
+ "Navigate up"
+ "More options"
+ "Done"
+ "See all"
+ "Choose an app"
+ "OFF"
+ "ON"
+ "Alt+"
+ "Ctrl+"
+ "delete"
+ "enter"
+ "Function+"
+ "Meta+"
+ "Shift+"
+ "space"
+ "Sym+"
+ "Menu+"
+ "Search…"
+ "Clear query"
+ "Search query"
+ "Search"
+ "Submit query"
+ "Voice search"
+ "Share with"
+ "Share with %s"
+ "Collapse"
+ "Search"
+ "999+"
+
\ No newline at end of file
diff --git a/src/src/app/build/intermediates/incremental/mergeDebugResources/merged.dir/values-en-rCA/values-en-rCA.xml b/src/src/app/build/intermediates/incremental/mergeDebugResources/merged.dir/values-en-rCA/values-en-rCA.xml
new file mode 100644
index 0000000..0b21ff7
--- /dev/null
+++ b/src/src/app/build/intermediates/incremental/mergeDebugResources/merged.dir/values-en-rCA/values-en-rCA.xml
@@ -0,0 +1,32 @@
+
+
+ "Navigate home"
+ "Navigate up"
+ "More options"
+ "Done"
+ "See all"
+ "Choose an app"
+ "OFF"
+ "ON"
+ "Alt+"
+ "Ctrl+"
+ "delete"
+ "enter"
+ "Function+"
+ "Meta+"
+ "Shift+"
+ "space"
+ "Sym+"
+ "Menu+"
+ "Search…"
+ "Clear query"
+ "Search query"
+ "Search"
+ "Submit query"
+ "Voice search"
+ "Share with"
+ "Share with %s"
+ "Collapse"
+ "Search"
+ "999+"
+
\ No newline at end of file
diff --git a/src/src/app/build/intermediates/incremental/mergeDebugResources/merged.dir/values-en-rGB/values-en-rGB.xml b/src/src/app/build/intermediates/incremental/mergeDebugResources/merged.dir/values-en-rGB/values-en-rGB.xml
new file mode 100644
index 0000000..0b21ff7
--- /dev/null
+++ b/src/src/app/build/intermediates/incremental/mergeDebugResources/merged.dir/values-en-rGB/values-en-rGB.xml
@@ -0,0 +1,32 @@
+
+
+ "Navigate home"
+ "Navigate up"
+ "More options"
+ "Done"
+ "See all"
+ "Choose an app"
+ "OFF"
+ "ON"
+ "Alt+"
+ "Ctrl+"
+ "delete"
+ "enter"
+ "Function+"
+ "Meta+"
+ "Shift+"
+ "space"
+ "Sym+"
+ "Menu+"
+ "Search…"
+ "Clear query"
+ "Search query"
+ "Search"
+ "Submit query"
+ "Voice search"
+ "Share with"
+ "Share with %s"
+ "Collapse"
+ "Search"
+ "999+"
+
\ No newline at end of file
diff --git a/src/src/app/build/intermediates/incremental/mergeDebugResources/merged.dir/values-en-rIN/values-en-rIN.xml b/src/src/app/build/intermediates/incremental/mergeDebugResources/merged.dir/values-en-rIN/values-en-rIN.xml
new file mode 100644
index 0000000..0b21ff7
--- /dev/null
+++ b/src/src/app/build/intermediates/incremental/mergeDebugResources/merged.dir/values-en-rIN/values-en-rIN.xml
@@ -0,0 +1,32 @@
+
+
+ "Navigate home"
+ "Navigate up"
+ "More options"
+ "Done"
+ "See all"
+ "Choose an app"
+ "OFF"
+ "ON"
+ "Alt+"
+ "Ctrl+"
+ "delete"
+ "enter"
+ "Function+"
+ "Meta+"
+ "Shift+"
+ "space"
+ "Sym+"
+ "Menu+"
+ "Search…"
+ "Clear query"
+ "Search query"
+ "Search"
+ "Submit query"
+ "Voice search"
+ "Share with"
+ "Share with %s"
+ "Collapse"
+ "Search"
+ "999+"
+
\ No newline at end of file
diff --git a/src/src/app/build/intermediates/incremental/mergeDebugResources/merged.dir/values-en-rXC/values-en-rXC.xml b/src/src/app/build/intermediates/incremental/mergeDebugResources/merged.dir/values-en-rXC/values-en-rXC.xml
new file mode 100644
index 0000000..52e1a7d
--- /dev/null
+++ b/src/src/app/build/intermediates/incremental/mergeDebugResources/merged.dir/values-en-rXC/values-en-rXC.xml
@@ -0,0 +1,32 @@
+
+
+ "Navigate home"
+ "Navigate up"
+ "More options"
+ "Done"
+ "See all"
+ "Choose an app"
+ "OFF"
+ "ON"
+ "Alt+"
+ "Ctrl+"
+ "delete"
+ "enter"
+ "Function+"
+ "Meta+"
+ "Shift+"
+ "space"
+ "Sym+"
+ "Menu+"
+ "Search…"
+ "Clear query"
+ "Search query"
+ "Search"
+ "Submit query"
+ "Voice search"
+ "Share with"
+ "Share with %s"
+ "Collapse"
+ "Search"
+ "999+"
+
\ No newline at end of file
diff --git a/src/src/app/build/intermediates/incremental/mergeDebugResources/merged.dir/values-es-rUS/values-es-rUS.xml b/src/src/app/build/intermediates/incremental/mergeDebugResources/merged.dir/values-es-rUS/values-es-rUS.xml
new file mode 100644
index 0000000..edb8524
--- /dev/null
+++ b/src/src/app/build/intermediates/incremental/mergeDebugResources/merged.dir/values-es-rUS/values-es-rUS.xml
@@ -0,0 +1,32 @@
+
+
+ "Navegar a la página principal"
+ "Navegar hacia arriba"
+ "Más opciones"
+ "Listo"
+ "Ver todo"
+ "Elige una aplicación."
+ "DESACTIVADO"
+ "ACTIVADO"
+ "Alt+"
+ "Ctrl+"
+ "borrar"
+ "intro"
+ "Función+"
+ "Meta+"
+ "Mayúscula+"
+ "espacio"
+ "Sym+"
+ "Menú+"
+ "Buscar…"
+ "Eliminar la consulta"
+ "Búsqueda"
+ "Búsqueda"
+ "Enviar consulta"
+ "Búsqueda por voz"
+ "Compartir con"
+ "Compartir con %s"
+ "Contraer"
+ "Buscar"
+ "999+"
+
\ No newline at end of file
diff --git a/src/src/app/build/intermediates/incremental/mergeDebugResources/merged.dir/values-es/values-es.xml b/src/src/app/build/intermediates/incremental/mergeDebugResources/merged.dir/values-es/values-es.xml
new file mode 100644
index 0000000..d2265ad
--- /dev/null
+++ b/src/src/app/build/intermediates/incremental/mergeDebugResources/merged.dir/values-es/values-es.xml
@@ -0,0 +1,32 @@
+
+
+ "Ir a la pantalla de inicio"
+ "Desplazarse hacia arriba"
+ "Más opciones"
+ "Listo"
+ "Ver todo"
+ "Seleccionar una aplicación"
+ "DESACTIVADO"
+ "ACTIVADO"
+ "Alt +"
+ "Ctrl +"
+ "Eliminar"
+ "Intro"
+ "Función +"
+ "Meta +"
+ "Mayús +"
+ "Espacio"
+ "Sym +"
+ "Menú +"
+ "Buscar…"
+ "Borrar consulta"
+ "Consulta"
+ "Buscar"
+ "Enviar consulta"
+ "Búsqueda por voz"
+ "Compartir con"
+ "Compartir con %s"
+ "Contraer"
+ "Buscar"
+ "+999"
+
\ No newline at end of file
diff --git a/src/src/app/build/intermediates/incremental/mergeDebugResources/merged.dir/values-et/values-et.xml b/src/src/app/build/intermediates/incremental/mergeDebugResources/merged.dir/values-et/values-et.xml
new file mode 100644
index 0000000..05be6e9
--- /dev/null
+++ b/src/src/app/build/intermediates/incremental/mergeDebugResources/merged.dir/values-et/values-et.xml
@@ -0,0 +1,32 @@
+
+
+ "Navigeerimine avaekraanile"
+ "Navigeerimine üles"
+ "Rohkem valikuid"
+ "Valmis"
+ "Kuva kõik"
+ "Valige rakendus"
+ "VÄLJAS"
+ "SEES"
+ "Alt +"
+ "Ctrl +"
+ "kustutamisklahv"
+ "sisestusklahv"
+ "Funktsiooniklahv +"
+ "Meta +"
+ "Tõstuklahv +"
+ "tühik"
+ "Sym +"
+ "Menüü +"
+ "Otsige …"
+ "Päringu tühistamine"
+ "Otsingupäring"
+ "Otsing"
+ "Päringu esitamine"
+ "Häälotsing"
+ "Jagamine:"
+ "Jagamine rakendusega %s"
+ "Ahendamine"
+ "Otsing"
+ "999+"
+
\ No newline at end of file
diff --git a/src/src/app/build/intermediates/incremental/mergeDebugResources/merged.dir/values-eu/values-eu.xml b/src/src/app/build/intermediates/incremental/mergeDebugResources/merged.dir/values-eu/values-eu.xml
new file mode 100644
index 0000000..8c09875
--- /dev/null
+++ b/src/src/app/build/intermediates/incremental/mergeDebugResources/merged.dir/values-eu/values-eu.xml
@@ -0,0 +1,32 @@
+
+
+ "Joan orri nagusira"
+ "Joan gora"
+ "Aukera gehiago"
+ "Eginda"
+ "Ikusi guztiak"
+ "Aukeratu aplikazio bat"
+ "DESAKTIBATUTA"
+ "AKTIBATUTA"
+ "Alt +"
+ "Ktrl +"
+ "Ezabatu"
+ "Sartu"
+ "Funtzioa +"
+ "Meta +"
+ "Maius +"
+ "Zuriunea"
+ "Sym +"
+ "Menua +"
+ "Bilatu…"
+ "Garbitu kontsulta"
+ "Bilaketa-kontsulta"
+ "Bilatu"
+ "Bidali kontsulta"
+ "Ahozko bilaketa"
+ "Partekatu hauekin"
+ "Partekatu %s aplikazioarekin"
+ "Tolestu"
+ "Bilatu"
+ "999+"
+
\ No newline at end of file
diff --git a/src/src/app/build/intermediates/incremental/mergeDebugResources/merged.dir/values-fa/values-fa.xml b/src/src/app/build/intermediates/incremental/mergeDebugResources/merged.dir/values-fa/values-fa.xml
new file mode 100644
index 0000000..90b2898
--- /dev/null
+++ b/src/src/app/build/intermediates/incremental/mergeDebugResources/merged.dir/values-fa/values-fa.xml
@@ -0,0 +1,32 @@
+
+
+ "پیمایش به صفحه اصلی"
+ "پیمایش به بالا"
+ "گزینههای بیشتر"
+ "تمام"
+ "مشاهده همه"
+ "انتخاب برنامه"
+ "خاموش"
+ "روشن"
+ "Alt+"
+ "Ctrl+"
+ "delete"
+ "enter"
+ "Function+"
+ "Meta+"
+ "Shift+"
+ "کلید فاصله"
+ "Sym+"
+ "منو+"
+ "جستجو…"
+ "پاک کردن عبارت جستجو"
+ "عبارت جستجو"
+ "جستجو"
+ "ارسال عبارت جستجو"
+ "جستجوی گفتاری"
+ "اشتراکگذاری با"
+ "اشتراکگذاری با %s"
+ "کوچک کردن"
+ "جستجو"
+ "999+"
+
\ No newline at end of file
diff --git a/src/src/app/build/intermediates/incremental/mergeDebugResources/merged.dir/values-fi/values-fi.xml b/src/src/app/build/intermediates/incremental/mergeDebugResources/merged.dir/values-fi/values-fi.xml
new file mode 100644
index 0000000..75b02bb
--- /dev/null
+++ b/src/src/app/build/intermediates/incremental/mergeDebugResources/merged.dir/values-fi/values-fi.xml
@@ -0,0 +1,32 @@
+
+
+ "Siirry etusivulle"
+ "Siirry ylös"
+ "Lisää"
+ "Valmis"
+ "Näytä kaikki"
+ "Valitse sovellus"
+ "POIS KÄYTÖSTÄ"
+ "KÄYTÖSSÄ"
+ "Alt+"
+ "Ctrl+"
+ "delete"
+ "enter"
+ "Fn+"
+ "Meta+"
+ "Vaihto+"
+ "välilyönti"
+ "Sym+"
+ "Valikko+"
+ "Haku…"
+ "Tyhjennä kysely"
+ "Hakulauseke"
+ "Haku"
+ "Lähetä kysely"
+ "Puhehaku"
+ "Jakaminen:"
+ "Jaa sovelluksessa %s"
+ "Kutista"
+ "Haku"
+ "999+"
+
\ No newline at end of file
diff --git a/src/src/app/build/intermediates/incremental/mergeDebugResources/merged.dir/values-fr-rCA/values-fr-rCA.xml b/src/src/app/build/intermediates/incremental/mergeDebugResources/merged.dir/values-fr-rCA/values-fr-rCA.xml
new file mode 100644
index 0000000..f71cf03
--- /dev/null
+++ b/src/src/app/build/intermediates/incremental/mergeDebugResources/merged.dir/values-fr-rCA/values-fr-rCA.xml
@@ -0,0 +1,32 @@
+
+
+ "Revenir à l\'accueil"
+ "Revenir en haut de la page"
+ "Plus d\'options"
+ "Terminé"
+ "Voir toutes les chaînes"
+ "Sélectionnez une application"
+ "DÉSACTIVÉ"
+ "ACTIVÉ"
+ "Alt+"
+ "Ctrl+"
+ "supprimer"
+ "entrée"
+ "Fonction+"
+ "Méta+"
+ "Maj+"
+ "espace"
+ "Sym+"
+ "Menu+"
+ "Recherche en cours..."
+ "Effacer la requête"
+ "Requête de recherche"
+ "Rechercher"
+ "Envoyer la requête"
+ "Recherche vocale"
+ "Partager"
+ "Partager avec %s"
+ "Réduire"
+ "Rechercher"
+ "999+"
+
\ No newline at end of file
diff --git a/src/src/app/build/intermediates/incremental/mergeDebugResources/merged.dir/values-fr/values-fr.xml b/src/src/app/build/intermediates/incremental/mergeDebugResources/merged.dir/values-fr/values-fr.xml
new file mode 100644
index 0000000..2aee397
--- /dev/null
+++ b/src/src/app/build/intermediates/incremental/mergeDebugResources/merged.dir/values-fr/values-fr.xml
@@ -0,0 +1,32 @@
+
+
+ "Revenir à l\'accueil"
+ "Revenir en haut de la page"
+ "Plus d\'options"
+ "OK"
+ "Tout afficher"
+ "Sélectionner une application"
+ "DÉSACTIVÉ"
+ "ACTIVÉ"
+ "Alt+"
+ "Ctrl+"
+ "supprimer"
+ "entrée"
+ "Fonction+"
+ "Méta+"
+ "Maj+"
+ "espace"
+ "Sym+"
+ "Menu+"
+ "Rechercher…"
+ "Effacer la requête"
+ "Requête de recherche"
+ "Rechercher"
+ "Envoyer la requête"
+ "Recherche vocale"
+ "Partager avec"
+ "Partager avec %s"
+ "Réduire"
+ "Rechercher"
+ "999+"
+
\ No newline at end of file
diff --git a/src/src/app/build/intermediates/incremental/mergeDebugResources/merged.dir/values-gl/values-gl.xml b/src/src/app/build/intermediates/incremental/mergeDebugResources/merged.dir/values-gl/values-gl.xml
new file mode 100644
index 0000000..d0081c6
--- /dev/null
+++ b/src/src/app/build/intermediates/incremental/mergeDebugResources/merged.dir/values-gl/values-gl.xml
@@ -0,0 +1,32 @@
+
+
+ "Ir á páxina de inicio"
+ "Desprazarse cara arriba"
+ "Máis opcións"
+ "Feito"
+ "Ver todas"
+ "Escoller unha aplicación"
+ "DESACTIVAR"
+ "ACTIVAR"
+ "Alt +"
+ "Ctrl +"
+ "eliminar"
+ "Intro"
+ "Función +"
+ "Meta +"
+ "Maiús +"
+ "espazo"
+ "Sim +"
+ "Menú +"
+ "Buscar…"
+ "Borrar consulta"
+ "Consulta de busca"
+ "Buscar"
+ "Enviar consulta"
+ "Busca por voz"
+ "Compartir con"
+ "Compartir con %s"
+ "Contraer"
+ "Buscar"
+ ">999"
+
\ No newline at end of file
diff --git a/src/src/app/build/intermediates/incremental/mergeDebugResources/merged.dir/values-gu/values-gu.xml b/src/src/app/build/intermediates/incremental/mergeDebugResources/merged.dir/values-gu/values-gu.xml
new file mode 100644
index 0000000..0a3b83b
--- /dev/null
+++ b/src/src/app/build/intermediates/incremental/mergeDebugResources/merged.dir/values-gu/values-gu.xml
@@ -0,0 +1,32 @@
+
+
+ "હોમ પર નેવિગેટ કરો"
+ "ઉપર નૅવિગેટ કરો"
+ "વધુ વિકલ્પો"
+ "થઈ ગયું"
+ "બધું જુઓ"
+ "એક ઍપ્લિકેશન પસંદ કરો"
+ "બંધ"
+ "ચાલુ"
+ "Alt+"
+ "Ctrl+"
+ "ડિલીટ કરો"
+ "Enter"
+ "Function+"
+ "Meta+"
+ "Shift+"
+ "Spacebar"
+ "Sym+"
+ "મેનૂ+"
+ "શોધો…"
+ "ક્વેરી સાફ કરો"
+ "શોધ ક્વેરી"
+ "શોધો"
+ "ક્વેરી સબમિટ કરો"
+ "વૉઇસ શોધ"
+ "આની સાથે શેર કરો"
+ "%sની સાથે શેર કરો"
+ "સંકુચિત કરો"
+ "શોધો"
+ "999+"
+
\ No newline at end of file
diff --git a/src/src/app/build/intermediates/incremental/mergeDebugResources/merged.dir/values-h720dp-v13/values-h720dp-v13.xml b/src/src/app/build/intermediates/incremental/mergeDebugResources/merged.dir/values-h720dp-v13/values-h720dp-v13.xml
new file mode 100644
index 0000000..e38bb90
--- /dev/null
+++ b/src/src/app/build/intermediates/incremental/mergeDebugResources/merged.dir/values-h720dp-v13/values-h720dp-v13.xml
@@ -0,0 +1,4 @@
+
+
+ 54dip
+
\ No newline at end of file
diff --git a/src/src/app/build/intermediates/incremental/mergeDebugResources/merged.dir/values-hdpi-v4/values-hdpi-v4.xml b/src/src/app/build/intermediates/incremental/mergeDebugResources/merged.dir/values-hdpi-v4/values-hdpi-v4.xml
new file mode 100644
index 0000000..d5a138e
--- /dev/null
+++ b/src/src/app/build/intermediates/incremental/mergeDebugResources/merged.dir/values-hdpi-v4/values-hdpi-v4.xml
@@ -0,0 +1,8 @@
+
+
+
+
\ No newline at end of file
diff --git a/src/src/app/build/intermediates/incremental/mergeDebugResources/merged.dir/values-hi/values-hi.xml b/src/src/app/build/intermediates/incremental/mergeDebugResources/merged.dir/values-hi/values-hi.xml
new file mode 100644
index 0000000..6576cb7
--- /dev/null
+++ b/src/src/app/build/intermediates/incremental/mergeDebugResources/merged.dir/values-hi/values-hi.xml
@@ -0,0 +1,32 @@
+
+
+ "होम पेज पर जाएं"
+ "ऊपर जाएं"
+ "ज़्यादा विकल्प"
+ "हो गया"
+ "सभी देखें"
+ "कोई एप्लिकेशन चुनें"
+ "बंद"
+ "चालू"
+ "Alt+"
+ "Ctrl+"
+ "delete"
+ "enter"
+ "Function+"
+ "Meta+"
+ "Shift+"
+ "space"
+ "Sym+"
+ "Menu+"
+ "खोजा जा रहा है…"
+ "क्वेरी साफ़ करें"
+ "सर्च क्वेरी"
+ "सर्च करें"
+ "क्वेरी सबमिट करें"
+ "आवाज़ सर्च"
+ "इसके साथ शेयर करें"
+ "%s के साथ शेयर करें"
+ "छोटा करें"
+ "सर्च"
+ "999+"
+
\ No newline at end of file
diff --git a/src/src/app/build/intermediates/incremental/mergeDebugResources/merged.dir/values-hr/values-hr.xml b/src/src/app/build/intermediates/incremental/mergeDebugResources/merged.dir/values-hr/values-hr.xml
new file mode 100644
index 0000000..2c3e6ae
--- /dev/null
+++ b/src/src/app/build/intermediates/incremental/mergeDebugResources/merged.dir/values-hr/values-hr.xml
@@ -0,0 +1,32 @@
+
+
+ "Idi na početnu"
+ "Idi gore"
+ "Dodatne opcije"
+ "Gotovo"
+ "Prikaži sve"
+ "Odabir aplikacije"
+ "ISKLJUČENO"
+ "UKLJUČENO"
+ "Alt+"
+ "Ctrl+"
+ "delete"
+ "enter"
+ "Function+"
+ "Meta+"
+ "Shift+"
+ "razmaknica"
+ "Sym+"
+ "Menu+"
+ "Pretražite…"
+ "Izbriši upit"
+ "Upit za pretraživanje"
+ "Pretraživanje"
+ "Pošalji upit"
+ "Glasovno pretraživanje"
+ "Dijeljenje sa"
+ "Dijeli putem aplikacije %s"
+ "Sažmi"
+ "Pretraživanje"
+ "999+"
+
\ No newline at end of file
diff --git a/src/src/app/build/intermediates/incremental/mergeDebugResources/merged.dir/values-hu/values-hu.xml b/src/src/app/build/intermediates/incremental/mergeDebugResources/merged.dir/values-hu/values-hu.xml
new file mode 100644
index 0000000..f980def
--- /dev/null
+++ b/src/src/app/build/intermediates/incremental/mergeDebugResources/merged.dir/values-hu/values-hu.xml
@@ -0,0 +1,32 @@
+
+
+ "Ugrás a főoldalra"
+ "Felfelé mozgatás"
+ "További lehetőségek"
+ "Kész"
+ "Összes megtekintése"
+ "Válasszon ki egy alkalmazást"
+ "KI"
+ "BE"
+ "Alt+"
+ "Ctrl+"
+ "Delete"
+ "Enter"
+ "Function+"
+ "Meta+"
+ "Shift+"
+ "Szóköz"
+ "Sym+"
+ "Menu+"
+ "Keresés…"
+ "Lekérdezés törlése"
+ "Keresési lekérdezés"
+ "Keresés"
+ "Lekérdezés küldése"
+ "Hangalapú keresés"
+ "Megosztás a következővel:"
+ "Megosztás a következő alkalmazással: %s"
+ "Összecsukás"
+ "Keresés"
+ "999+"
+
\ No newline at end of file
diff --git a/src/src/app/build/intermediates/incremental/mergeDebugResources/merged.dir/values-hy/values-hy.xml b/src/src/app/build/intermediates/incremental/mergeDebugResources/merged.dir/values-hy/values-hy.xml
new file mode 100644
index 0000000..3247f9a
--- /dev/null
+++ b/src/src/app/build/intermediates/incremental/mergeDebugResources/merged.dir/values-hy/values-hy.xml
@@ -0,0 +1,32 @@
+
+
+ "Ուղղվել տուն"
+ "Ուղղվել վերև"
+ "Այլ ընտրանքներ"
+ "Պատրաստ է"
+ "Տեսնել բոլորը"
+ "Ընտրել ծրագիր"
+ "ԱՆՋԱՏՎԱԾ"
+ "ՄԻԱՑՎԱԾ"
+ "Alt+"
+ "Ctrl+"
+ "Delete"
+ "Enter"
+ "Function+"
+ "Meta+"
+ "Shift+"
+ "բացատ"
+ "Sym+"
+ "Menu+"
+ "Որոնում..."
+ "Մաքրել հարցումը"
+ "Որոնման հարցում"
+ "Որոնել"
+ "Ուղարկել հարցումը"
+ "Ձայնային որոնում"
+ "Կիսվել"
+ "Ուղարկել %s-ին"
+ "Թաքցնել"
+ "Որոնել"
+ "999+"
+
\ No newline at end of file
diff --git a/src/src/app/build/intermediates/incremental/mergeDebugResources/merged.dir/values-in/values-in.xml b/src/src/app/build/intermediates/incremental/mergeDebugResources/merged.dir/values-in/values-in.xml
new file mode 100644
index 0000000..314af7e
--- /dev/null
+++ b/src/src/app/build/intermediates/incremental/mergeDebugResources/merged.dir/values-in/values-in.xml
@@ -0,0 +1,32 @@
+
+
+ "Navigasi ke beranda"
+ "Navigasi naik"
+ "Opsi lain"
+ "Selesai"
+ "Lihat semua"
+ "Pilih aplikasi"
+ "NONAKTIF"
+ "AKTIF"
+ "Alt+"
+ "Ctrl+"
+ "delete"
+ "enter"
+ "Function+"
+ "Meta+"
+ "Shift+"
+ "spasi"
+ "Sym+"
+ "Menu+"
+ "Telusuri..."
+ "Hapus kueri"
+ "Kueri penelusuran"
+ "Telusuri"
+ "Kirim kueri"
+ "Penelusuran suara"
+ "Bagikan dengan"
+ "Bagikan ke %s"
+ "Ciutkan"
+ "Telusuri"
+ "999+"
+
\ No newline at end of file
diff --git a/src/src/app/build/intermediates/incremental/mergeDebugResources/merged.dir/values-is/values-is.xml b/src/src/app/build/intermediates/incremental/mergeDebugResources/merged.dir/values-is/values-is.xml
new file mode 100644
index 0000000..58321f7
--- /dev/null
+++ b/src/src/app/build/intermediates/incremental/mergeDebugResources/merged.dir/values-is/values-is.xml
@@ -0,0 +1,32 @@
+
+
+ "Fara heim"
+ "Fara upp"
+ "Fleiri valkostir"
+ "Lokið"
+ "Sjá allt"
+ "Veldu forrit"
+ "SLÖKKT"
+ "KVEIKT"
+ "Alt+"
+ "Ctrl+"
+ "delete"
+ "enter"
+ "Aðgerðarlykill+"
+ "Meta+"
+ "Shift+"
+ "bilslá"
+ "Sym+"
+ "Valmynd+"
+ "Leita…"
+ "Hreinsa fyrirspurn"
+ "Leitarfyrirspurn"
+ "Leita"
+ "Senda fyrirspurn"
+ "Raddleit"
+ "Deila með"
+ "Deila með %s"
+ "Minnka"
+ "Leita"
+ "999+"
+
\ No newline at end of file
diff --git a/src/src/app/build/intermediates/incremental/mergeDebugResources/merged.dir/values-it/values-it.xml b/src/src/app/build/intermediates/incremental/mergeDebugResources/merged.dir/values-it/values-it.xml
new file mode 100644
index 0000000..48842b3
--- /dev/null
+++ b/src/src/app/build/intermediates/incremental/mergeDebugResources/merged.dir/values-it/values-it.xml
@@ -0,0 +1,32 @@
+
+
+ "Vai alla home page"
+ "Vai in alto"
+ "Altre opzioni"
+ "Fine"
+ "Visualizza tutte"
+ "Scegli un\'applicazione"
+ "OFF"
+ "ON"
+ "ALT +"
+ "CTRL +"
+ "CANC"
+ "INVIO"
+ "FUNZIONE +"
+ "META +"
+ "MAIUSC +"
+ "barra spaziatrice"
+ "SYM +"
+ "MENU +"
+ "Cerca…"
+ "Cancella query"
+ "Query di ricerca"
+ "Cerca"
+ "Invia query"
+ "Ricerca vocale"
+ "Condividi con"
+ "Condividi tramite %s"
+ "Comprimi"
+ "Ricerca"
+ "999+"
+
\ No newline at end of file
diff --git a/src/src/app/build/intermediates/incremental/mergeDebugResources/merged.dir/values-iw/values-iw.xml b/src/src/app/build/intermediates/incremental/mergeDebugResources/merged.dir/values-iw/values-iw.xml
new file mode 100644
index 0000000..ed74d57
--- /dev/null
+++ b/src/src/app/build/intermediates/incremental/mergeDebugResources/merged.dir/values-iw/values-iw.xml
@@ -0,0 +1,32 @@
+
+
+ "נווט לדף הבית"
+ "נווט למעלה"
+ "עוד אפשרויות"
+ "בוצע"
+ "ראה הכל"
+ "בחר אפליקציה"
+ "כבוי"
+ "פועל"
+ "Alt+"
+ "Ctrl+"
+ "delete"
+ "Enter"
+ "Function+"
+ "Meta+"
+ "Shift+"
+ "מקש רווח"
+ "Sym+"
+ "תפריט+"
+ "חיפוש…"
+ "מחק שאילתה"
+ "שאילתת חיפוש"
+ "חיפוש"
+ "שלח שאילתה"
+ "חיפוש קולי"
+ "שתף עם"
+ "שתף עם %s"
+ "כווץ"
+ "חיפוש"
+ "999+"
+
\ No newline at end of file
diff --git a/src/src/app/build/intermediates/incremental/mergeDebugResources/merged.dir/values-ja/values-ja.xml b/src/src/app/build/intermediates/incremental/mergeDebugResources/merged.dir/values-ja/values-ja.xml
new file mode 100644
index 0000000..6be4581
--- /dev/null
+++ b/src/src/app/build/intermediates/incremental/mergeDebugResources/merged.dir/values-ja/values-ja.xml
@@ -0,0 +1,32 @@
+
+
+ "ホームへ移動"
+ "上へ移動"
+ "その他のオプション"
+ "完了"
+ "すべて表示"
+ "アプリの選択"
+ "OFF"
+ "ON"
+ "Alt+"
+ "Ctrl+"
+ "Delete"
+ "Enter"
+ "Function+"
+ "Meta+"
+ "Shift+"
+ "Space"
+ "Sym+"
+ "Menu+"
+ "検索…"
+ "検索キーワードを削除"
+ "検索キーワード"
+ "検索"
+ "検索キーワードを送信"
+ "音声検索"
+ "共有"
+ "%sと共有"
+ "折りたたむ"
+ "検索"
+ "999+"
+
\ No newline at end of file
diff --git a/src/src/app/build/intermediates/incremental/mergeDebugResources/merged.dir/values-ka/values-ka.xml b/src/src/app/build/intermediates/incremental/mergeDebugResources/merged.dir/values-ka/values-ka.xml
new file mode 100644
index 0000000..8e91c0a
--- /dev/null
+++ b/src/src/app/build/intermediates/incremental/mergeDebugResources/merged.dir/values-ka/values-ka.xml
@@ -0,0 +1,32 @@
+
+
+ "მთავარზე ნავიგაცია"
+ "ზემოთ ნავიგაცია"
+ "მეტი ვარიანტები"
+ "დასრულდა"
+ "ყველას ნახვა"
+ "აპის არჩევა"
+ "გამორთულია"
+ "ჩართულია"
+ "Alt+"
+ "Ctrl+"
+ "წაშლა"
+ "შეყვანა"
+ "Function+"
+ "Meta+"
+ "Shift+"
+ "space"
+ "Sym+"
+ "Menu+"
+ "ძიება..."
+ "მოთხოვნის გასუფთავება"
+ "ძიების მოთხოვნა"
+ "ძიება"
+ "მოთხოვნის გადაგზავნა"
+ "ხმოვანი ძიება"
+ "გაზიარება:"
+ "გაუზიარეთ %s-ს"
+ "აკეცვა"
+ "ძიება"
+ "999+"
+
\ No newline at end of file
diff --git a/src/src/app/build/intermediates/incremental/mergeDebugResources/merged.dir/values-kk/values-kk.xml b/src/src/app/build/intermediates/incremental/mergeDebugResources/merged.dir/values-kk/values-kk.xml
new file mode 100644
index 0000000..d9596d0
--- /dev/null
+++ b/src/src/app/build/intermediates/incremental/mergeDebugResources/merged.dir/values-kk/values-kk.xml
@@ -0,0 +1,32 @@
+
+
+ "Негізгі бетте қозғалу"
+ "Жоғары қозғалу"
+ "Басқа опциялар"
+ "Дайын"
+ "Барлығын көру"
+ "Қолданбаны таңдау"
+ "ӨШІРУЛІ"
+ "ҚОСУЛЫ"
+ "Alt+"
+ "Ctrl+"
+ "delete"
+ "enter"
+ "Function+"
+ "Meta+"
+ "Shift+"
+ "бос орын"
+ "Sym+"
+ "Mәзір+"
+ "Іздеу…"
+ "Сұрақты жою"
+ "Сұрақты іздеу"
+ "Іздеу"
+ "Сұрақты жіберу"
+ "Дауыс арқылы іздеу"
+ "Бөлісу"
+ "%s қолданбасымен бөлісу"
+ "Тасалау"
+ "Іздеу"
+ "999+"
+
\ No newline at end of file
diff --git a/src/src/app/build/intermediates/incremental/mergeDebugResources/merged.dir/values-km/values-km.xml b/src/src/app/build/intermediates/incremental/mergeDebugResources/merged.dir/values-km/values-km.xml
new file mode 100644
index 0000000..57735d2
--- /dev/null
+++ b/src/src/app/build/intermediates/incremental/mergeDebugResources/merged.dir/values-km/values-km.xml
@@ -0,0 +1,32 @@
+
+
+ "រកមើលទៅដើម"
+ "រកមើលឡើងលើ"
+ "ជម្រើសច្រើនទៀត"
+ "រួចរាល់"
+ "មើលទាំងអស់"
+ "ជ្រើសកម្មវិធី"
+ "បិទ"
+ "បើក"
+ "Alt+"
+ "Ctrl+"
+ "delete"
+ "enter"
+ "Function+"
+ "Meta+"
+ "Shift+"
+ "space"
+ "Sym+"
+ "Menu+"
+ "ស្វែងរក…"
+ "សម្អាតសំណួរ"
+ "ស្វែងរកសំណួរ"
+ "ស្វែងរក"
+ "ដាក់ស្នើសំណួរ"
+ "ការស្វែងរកសំឡេង"
+ "ចែករំលែកជាមួយ"
+ "ចែករំលែកជាមួយ %s"
+ "បង្រួម"
+ "ស្វែងរក"
+ "999+"
+
\ No newline at end of file
diff --git a/src/src/app/build/intermediates/incremental/mergeDebugResources/merged.dir/values-kn/values-kn.xml b/src/src/app/build/intermediates/incremental/mergeDebugResources/merged.dir/values-kn/values-kn.xml
new file mode 100644
index 0000000..1e2402b
--- /dev/null
+++ b/src/src/app/build/intermediates/incremental/mergeDebugResources/merged.dir/values-kn/values-kn.xml
@@ -0,0 +1,32 @@
+
+
+ "ಮುಖಪುಟವನ್ನು ನ್ಯಾವಿಗೇಟ್ ಮಾಡಿ"
+ "ಮೇಲಕ್ಕೆ ನ್ಯಾವಿಗೇಟ್ ಮಾಡಿ"
+ "ಇನ್ನಷ್ಟು ಆಯ್ಕೆಗಳು"
+ "ಮುಗಿದಿದೆ"
+ "ಎಲ್ಲವನ್ನೂ ನೋಡಿ"
+ "ಒಂದು ಅಪ್ಲಿಕೇಶನ್ ಆಯ್ಕೆಮಾಡಿ"
+ "ಆಫ್"
+ "ಆನ್"
+ "Alt+"
+ "Ctrl+"
+ "delete"
+ "enter"
+ "Function+"
+ "Meta+"
+ "Shift+"
+ "space"
+ "Sym+"
+ "Menu+"
+ "ಹುಡುಕಿ…"
+ "ಪ್ರಶ್ನೆಯನ್ನು ತೆರವುಗೊಳಿಸು"
+ "ಪ್ರಶ್ನೆಯನ್ನು ಹುಡುಕಿ"
+ "ಹುಡುಕಿ"
+ "ಪ್ರಶ್ನೆಯನ್ನು ಸಲ್ಲಿಸು"
+ "ಧ್ವನಿ ಹುಡುಕಾಟ"
+ "ಇವರೊಂದಿಗೆ ಹಂಚಿಕೊಳ್ಳಿ"
+ "%s ನೊಂದಿಗೆ ಹಂಚಿಕೊಳ್ಳಿ"
+ "ಸಂಕುಚಿಸು"
+ "ಹುಡುಕಿ"
+ "999+"
+
\ No newline at end of file
diff --git a/src/src/app/build/intermediates/incremental/mergeDebugResources/merged.dir/values-ko/values-ko.xml b/src/src/app/build/intermediates/incremental/mergeDebugResources/merged.dir/values-ko/values-ko.xml
new file mode 100644
index 0000000..5e0d052
--- /dev/null
+++ b/src/src/app/build/intermediates/incremental/mergeDebugResources/merged.dir/values-ko/values-ko.xml
@@ -0,0 +1,32 @@
+
+
+ "홈 탐색"
+ "위로 탐색"
+ "옵션 더보기"
+ "완료"
+ "전체 보기"
+ "앱 선택"
+ "사용 안함"
+ "사용"
+ "Alt+"
+ "Ctrl+"
+ "삭제"
+ "입력"
+ "Function+"
+ "Meta+"
+ "Shift+"
+ "스페이스바"
+ "Sym+"
+ "Menu+"
+ "검색..."
+ "검색어 삭제"
+ "검색어"
+ "검색"
+ "검색어 보내기"
+ "음성 검색"
+ "공유 대상"
+ "%s와(과) 공유"
+ "접기"
+ "검색"
+ "999+"
+
\ No newline at end of file
diff --git a/src/src/app/build/intermediates/incremental/mergeDebugResources/merged.dir/values-ky/values-ky.xml b/src/src/app/build/intermediates/incremental/mergeDebugResources/merged.dir/values-ky/values-ky.xml
new file mode 100644
index 0000000..7a8bb7f
--- /dev/null
+++ b/src/src/app/build/intermediates/incremental/mergeDebugResources/merged.dir/values-ky/values-ky.xml
@@ -0,0 +1,32 @@
+
+
+ "Үйгө багыттоо"
+ "Жогору"
+ "Көбүрөөк мүмкүнчүлүктөр"
+ "Даяр"
+ "Бардыгын көрүү"
+ "Колдонмо тандоо"
+ "ӨЧҮК"
+ "КҮЙҮК"
+ "Alt+"
+ "Ctrl+"
+ "Delete"
+ "Enter"
+ "Function+"
+ "Meta+"
+ "Shift+"
+ "боштук"
+ "Sym+"
+ "Menu+"
+ "Издөө…"
+ "Талаптарды тазалоо"
+ "Издөө талаптары"
+ "Издөө"
+ "Талап жөнөтүү"
+ "Үн аркылуу издөө"
+ "Бөлүшүү"
+ "%s аркылуу бөлүшүү"
+ "Жыйнап коюу"
+ "Издөө"
+ "999+"
+
\ No newline at end of file
diff --git a/src/src/app/build/intermediates/incremental/mergeDebugResources/merged.dir/values-land/values-land.xml b/src/src/app/build/intermediates/incremental/mergeDebugResources/merged.dir/values-land/values-land.xml
new file mode 100644
index 0000000..a12899f
--- /dev/null
+++ b/src/src/app/build/intermediates/incremental/mergeDebugResources/merged.dir/values-land/values-land.xml
@@ -0,0 +1,6 @@
+
+
+ 48dp
+ 12dp
+ 14dp
+
\ No newline at end of file
diff --git a/src/src/app/build/intermediates/incremental/mergeDebugResources/merged.dir/values-large-v4/values-large-v4.xml b/src/src/app/build/intermediates/incremental/mergeDebugResources/merged.dir/values-large-v4/values-large-v4.xml
new file mode 100644
index 0000000..cc236eb
--- /dev/null
+++ b/src/src/app/build/intermediates/incremental/mergeDebugResources/merged.dir/values-large-v4/values-large-v4.xml
@@ -0,0 +1,12 @@
+
+
+ 440dp
+ 60%
+ 90%
+ 60%
+ 90%
+ 55%
+ 80%
+
+
+
\ No newline at end of file
diff --git a/src/src/app/build/intermediates/incremental/mergeDebugResources/merged.dir/values-ldltr-v21/values-ldltr-v21.xml b/src/src/app/build/intermediates/incremental/mergeDebugResources/merged.dir/values-ldltr-v21/values-ldltr-v21.xml
new file mode 100644
index 0000000..1bdd835
--- /dev/null
+++ b/src/src/app/build/intermediates/incremental/mergeDebugResources/merged.dir/values-ldltr-v21/values-ldltr-v21.xml
@@ -0,0 +1,4 @@
+
+
+
+
\ No newline at end of file
diff --git a/src/src/app/build/intermediates/incremental/mergeDebugResources/merged.dir/values-lo/values-lo.xml b/src/src/app/build/intermediates/incremental/mergeDebugResources/merged.dir/values-lo/values-lo.xml
new file mode 100644
index 0000000..589107a
--- /dev/null
+++ b/src/src/app/build/intermediates/incremental/mergeDebugResources/merged.dir/values-lo/values-lo.xml
@@ -0,0 +1,32 @@
+
+
+ "ກັບໄປໜ້າຫຼັກ"
+ "ຂຶ້ນເທິງ"
+ "ໂຕເລືອກອື່ນ"
+ "ແລ້ວໆ"
+ "ເບິ່ງທັງຫມົດ"
+ "ເລືອກແອັບຯ"
+ "ປິດ"
+ "ເປີດ"
+ "Alt+"
+ "Ctrl+"
+ "delete"
+ "enter"
+ "Function+"
+ "Meta+"
+ "Shift+"
+ "space"
+ "Sym+"
+ "Menu+"
+ "ຊອກຫາ"
+ "ລຶບຂໍ້ຄວາມຊອກຫາ"
+ "ຊອກຫາ"
+ "ຊອກຫາ"
+ "ສົ່ງການຊອກຫາ"
+ "ຊອກຫາດ້ວຍສຽງ"
+ "ແບ່ງປັນກັບ"
+ "ແບ່ງປັນດ້ວຍ %s"
+ "ຫຍໍ້"
+ "ຊອກຫາ"
+ "999+"
+
\ No newline at end of file
diff --git a/src/src/app/build/intermediates/incremental/mergeDebugResources/merged.dir/values-lt/values-lt.xml b/src/src/app/build/intermediates/incremental/mergeDebugResources/merged.dir/values-lt/values-lt.xml
new file mode 100644
index 0000000..6cf0bd3
--- /dev/null
+++ b/src/src/app/build/intermediates/incremental/mergeDebugResources/merged.dir/values-lt/values-lt.xml
@@ -0,0 +1,32 @@
+
+
+ "Eiti į pagrindinį puslapį"
+ "Eiti į viršų"
+ "Daugiau parinkčių"
+ "Atlikta"
+ "Peržiūrėti viską"
+ "Pasirinkti programą"
+ "IŠJUNGTA"
+ "ĮJUNGTI"
+ "„Alt“ +"
+ "„Ctrl“ +"
+ "„Delete“"
+ "„Enter“"
+ "„Function“ +"
+ "„Meta“ +"
+ "„Shift“ +"
+ "tarpo klavišas"
+ "„Sym“ +"
+ "„Menu“ +"
+ "Ieškoti..."
+ "Išvalyti užklausą"
+ "Paieškos užklausa"
+ "Paieška"
+ "Pateikti užklausą"
+ "Paieška balsu"
+ "Bendrinti naudojant"
+ "Bendrinti naudojant programą „%s“"
+ "Sutraukti"
+ "Paieška"
+ "999+"
+
\ No newline at end of file
diff --git a/src/src/app/build/intermediates/incremental/mergeDebugResources/merged.dir/values-lv/values-lv.xml b/src/src/app/build/intermediates/incremental/mergeDebugResources/merged.dir/values-lv/values-lv.xml
new file mode 100644
index 0000000..cb15601
--- /dev/null
+++ b/src/src/app/build/intermediates/incremental/mergeDebugResources/merged.dir/values-lv/values-lv.xml
@@ -0,0 +1,32 @@
+
+
+ "Pārvietoties uz sākuma ekrānu"
+ "Pārvietoties augšup"
+ "Vairāk opciju"
+ "Gatavs"
+ "Skatīt visu"
+ "Izvēlieties lietotni"
+ "IZSLĒGTS"
+ "IESLĒGTS"
+ "Alternēšanas taustiņš +"
+ "Vadīšanas taustiņš +"
+ "dzēšanas taustiņš"
+ "ievadīšanas taustiņš"
+ "Funkcijas taustiņš +"
+ "Meta taustiņš +"
+ "Pārslēgšanas taustiņš +"
+ "atstarpes taustiņš"
+ "Simbolu taustiņš +"
+ "Poga Izvēlne +"
+ "Meklējiet…"
+ "Notīrīt vaicājumu"
+ "Meklēšanas vaicājums"
+ "Meklēt"
+ "Iesniegt vaicājumu"
+ "Meklēšana ar balsi"
+ "Kopīgot ar:"
+ "Kopīgot ar lietojumprogrammu %s"
+ "Sakļaut"
+ "Meklēt"
+ "999+"
+
\ No newline at end of file
diff --git a/src/src/app/build/intermediates/incremental/mergeDebugResources/merged.dir/values-mk/values-mk.xml b/src/src/app/build/intermediates/incremental/mergeDebugResources/merged.dir/values-mk/values-mk.xml
new file mode 100644
index 0000000..6036a05
--- /dev/null
+++ b/src/src/app/build/intermediates/incremental/mergeDebugResources/merged.dir/values-mk/values-mk.xml
@@ -0,0 +1,32 @@
+
+
+ "Движи се кон дома"
+ "Движи се нагоре"
+ "Повеќе опции"
+ "Готово"
+ "Види ги сите"
+ "Избери апликација"
+ "ИСКЛУЧЕНО"
+ "ВКЛУЧЕНО"
+ "копче Alt+"
+ "копче Ctrl+"
+ "избриши"
+ "копче enter"
+ "копче Function+"
+ "копче Meta+"
+ "копче Shift+"
+ "вселена"
+ "копче Sym+"
+ "Мени+"
+ "Пребарување…"
+ "Исчисти барање"
+ "Пребарај барање"
+ "Пребарај"
+ "Поднеси барање"
+ "Гласовно пребарување"
+ "Сподели со"
+ "Сподели со %s"
+ "Собери"
+ "Пребарај"
+ "999+"
+
\ No newline at end of file
diff --git a/src/src/app/build/intermediates/incremental/mergeDebugResources/merged.dir/values-ml/values-ml.xml b/src/src/app/build/intermediates/incremental/mergeDebugResources/merged.dir/values-ml/values-ml.xml
new file mode 100644
index 0000000..99bafe5
--- /dev/null
+++ b/src/src/app/build/intermediates/incremental/mergeDebugResources/merged.dir/values-ml/values-ml.xml
@@ -0,0 +1,32 @@
+
+
+ "ഹോമിലേക്ക് നാവിഗേറ്റുചെയ്യുക"
+ "മുകളിലേക്ക് നാവിഗേറ്റുചെയ്യുക"
+ "കൂടുതൽ ഓപ്ഷനുകള്"
+ "പൂർത്തിയാക്കി"
+ "എല്ലാം കാണുക"
+ "ഒരു അപ്ലിക്കേഷൻ തിരഞ്ഞെടുക്കുക"
+ "ഓഫ്"
+ "ഓൺ"
+ "Alt+"
+ "Ctrl+"
+ "ഇല്ലാതാക്കുക"
+ "enter"
+ "ഫംഗ്ഷന്+"
+ "മെറ്റ+"
+ "Shift+"
+ "സ്പെയ്സ്"
+ "Sym+"
+ "മെനു+"
+ "തിരയുക…"
+ "അന്വേഷണം മായ്ക്കുക"
+ "തിരയൽ അന്വേഷണം"
+ "തിരയൽ"
+ "അന്വേഷണം സമർപ്പിക്കുക"
+ "ശബ്ദതിരയൽ"
+ "ഇവരുമായി പങ്കിടുക"
+ "%s-മായി പങ്കിടുക"
+ "ചുരുക്കുക"
+ "തിരയുക"
+ "999+"
+
\ No newline at end of file
diff --git a/src/src/app/build/intermediates/incremental/mergeDebugResources/merged.dir/values-mn/values-mn.xml b/src/src/app/build/intermediates/incremental/mergeDebugResources/merged.dir/values-mn/values-mn.xml
new file mode 100644
index 0000000..3b3db0e
--- /dev/null
+++ b/src/src/app/build/intermediates/incremental/mergeDebugResources/merged.dir/values-mn/values-mn.xml
@@ -0,0 +1,32 @@
+
+
+ "Нүүр хуудас руу шилжих"
+ "Дээш шилжих"
+ "Нэмэлт сонголтууд"
+ "Дууссан"
+ "Бүгдийг харах"
+ "Апп сонгох"
+ "ИДЭВХГҮЙ"
+ "ИДЭВХТЭЙ"
+ "Alt+"
+ "Ctrl+"
+ "устгах"
+ "оруулах"
+ "Функц+"
+ "Мета+"
+ "Shift+"
+ "зай"
+ "Sym+"
+ "Цэс+"
+ "Хайх..."
+ "Асуулгыг цэвэрлэх"
+ "Хайх асуулга"
+ "Хайх"
+ "Асуулгыг илгээх"
+ "Дуут хайлт"
+ "Хуваалцах"
+ "%s-тай хуваалцах"
+ "Хумих"
+ "Хайлт"
+ "999+"
+
\ No newline at end of file
diff --git a/src/src/app/build/intermediates/incremental/mergeDebugResources/merged.dir/values-mr/values-mr.xml b/src/src/app/build/intermediates/incremental/mergeDebugResources/merged.dir/values-mr/values-mr.xml
new file mode 100644
index 0000000..3ccf8cb
--- /dev/null
+++ b/src/src/app/build/intermediates/incremental/mergeDebugResources/merged.dir/values-mr/values-mr.xml
@@ -0,0 +1,32 @@
+
+
+ "होमवर नेव्हिगेट करा"
+ "वर नेव्हिगेट करा"
+ "अधिक पर्याय"
+ "पूर्ण झाले"
+ "सर्व पहा"
+ "एक अॅप निवडा"
+ "बंद"
+ "चालू"
+ "Alt+"
+ "Ctrl+"
+ "हटवा"
+ "एंटर करा"
+ "Function+"
+ "Meta+"
+ "Shift+"
+ "spacebar"
+ "Sym+"
+ "मेनू+"
+ "शोधा…"
+ "क्वेरी स्पष्ट करा"
+ "शोध क्वेरी"
+ "शोध"
+ "क्वेरी सबमिट करा"
+ "व्हॉइस शोध"
+ "यांच्यासह शेअर करा"
+ "%s सह शेअर करा"
+ "संक्षिप्त करा"
+ "शोधा"
+ "९९९+"
+
\ No newline at end of file
diff --git a/src/src/app/build/intermediates/incremental/mergeDebugResources/merged.dir/values-ms/values-ms.xml b/src/src/app/build/intermediates/incremental/mergeDebugResources/merged.dir/values-ms/values-ms.xml
new file mode 100644
index 0000000..6823a82
--- /dev/null
+++ b/src/src/app/build/intermediates/incremental/mergeDebugResources/merged.dir/values-ms/values-ms.xml
@@ -0,0 +1,32 @@
+
+
+ "Navigasi skrin utama"
+ "Navigasi ke atas"
+ "Lagi pilihan"
+ "Selesai"
+ "Lihat semua"
+ "Pilih apl"
+ "MATI"
+ "HIDUP"
+ "Alt+"
+ "Ctrl+"
+ "padam"
+ "enter"
+ "Fungsi+"
+ "Meta+"
+ "Shift+"
+ "ruang"
+ "Sym+"
+ "Menu+"
+ "Cari…"
+ "Kosongkan pertanyaan"
+ "Pertanyaan carian"
+ "Cari"
+ "Serah pertanyaan"
+ "Carian suara"
+ "Kongsi dengan"
+ "Kongsi dengan %s"
+ "Runtuhkan"
+ "Cari"
+ "999+"
+
\ No newline at end of file
diff --git a/src/src/app/build/intermediates/incremental/mergeDebugResources/merged.dir/values-my/values-my.xml b/src/src/app/build/intermediates/incremental/mergeDebugResources/merged.dir/values-my/values-my.xml
new file mode 100644
index 0000000..8d301b2
--- /dev/null
+++ b/src/src/app/build/intermediates/incremental/mergeDebugResources/merged.dir/values-my/values-my.xml
@@ -0,0 +1,32 @@
+
+
+ "မူလနေရာကို သွားရန်"
+ "အပေါ်သို့သွားရန်"
+ "ပိုမိုရွေးချယ်စရာများ"
+ "ပြီးဆုံးပါပြီ"
+ "အားလုံးကို ကြည့်ရန်"
+ "အက်ပ်တစ်ခုခုကို ရွေးချယ်ပါ"
+ "ပိတ်"
+ "ဖွင့်"
+ "Alt+"
+ "Ctrl+"
+ "delete"
+ "enter"
+ "Function+"
+ "Meta+"
+ "Shift+"
+ "space"
+ "Sym+"
+ "Menu+"
+ "ရှာဖွေပါ..."
+ "ရှာစရာ အချက်အလက်များ ဖယ်ရှားရန်"
+ "ရှာစရာ အချက်အလက်နေရာ"
+ "ရှာဖွေရန်"
+ "ရှာဖွေစရာ အချက်အလက်ကို ပေးပို့ရန်"
+ "အသံဖြင့် ရှာဖွေခြင်း"
+ "မျှဝေဖို့ ရွေးပါ"
+ "%s ဖြင့် မျှဝေရန်"
+ "ခေါက်ရန်"
+ "ရှာဖွေပါ"
+ "၉၉၉+"
+
\ No newline at end of file
diff --git a/src/src/app/build/intermediates/incremental/mergeDebugResources/merged.dir/values-nb/values-nb.xml b/src/src/app/build/intermediates/incremental/mergeDebugResources/merged.dir/values-nb/values-nb.xml
new file mode 100644
index 0000000..c9cff9e
--- /dev/null
+++ b/src/src/app/build/intermediates/incremental/mergeDebugResources/merged.dir/values-nb/values-nb.xml
@@ -0,0 +1,32 @@
+
+
+ "Gå til startsiden"
+ "Gå opp"
+ "Flere alternativer"
+ "Ferdig"
+ "Se alle"
+ "Velg en app"
+ "AV"
+ "PÅ"
+ "Alt+"
+ "Ctrl+"
+ "delete"
+ "enter"
+ "Funksjon+"
+ "Meta+"
+ "Shift+"
+ "mellomrom"
+ "Sym+"
+ "Meny+"
+ "Søk …"
+ "Slett søket"
+ "Søkeord"
+ "Søk"
+ "Utfør søket"
+ "Talesøk"
+ "Del med"
+ "Del med %s"
+ "Skjul"
+ "Søk"
+ "999+"
+
\ No newline at end of file
diff --git a/src/src/app/build/intermediates/incremental/mergeDebugResources/merged.dir/values-ne/values-ne.xml b/src/src/app/build/intermediates/incremental/mergeDebugResources/merged.dir/values-ne/values-ne.xml
new file mode 100644
index 0000000..d7b12d5
--- /dev/null
+++ b/src/src/app/build/intermediates/incremental/mergeDebugResources/merged.dir/values-ne/values-ne.xml
@@ -0,0 +1,32 @@
+
+
+ "गृह खोज्नुहोस्"
+ "माथि खोज्नुहोस्"
+ "थप विकल्पहरू"
+ "सम्पन्न भयो"
+ "सबै हेर्नुहोस्"
+ "एउटा अनुप्रयोग छान्नुहोस्"
+ "निष्क्रिय पार्नुहोस्"
+ "सक्रिय गर्नुहोस्"
+ "Alt+"
+ "Ctrl+"
+ "delete"
+ "enter"
+ "Function+"
+ "Meta+"
+ "Shift+"
+ "space"
+ "Sym+"
+ "Menu+"
+ "खोज्नुहोस्..."
+ "प्रश्न हटाउनुहोस्"
+ "जिज्ञासाको खोज गर्नुहोस्"
+ "खोज्नुहोस्"
+ "जिज्ञासा पेस गर्नुहोस्"
+ "भ्वाइस खोजी"
+ "साझेदारी गर्नुहोस्..."
+ "%s सँग आदान प्रदान गर्नुहोस्"
+ "संक्षिप्त पार्नुहोस्"
+ "खोज्नुहोस्"
+ "९९९+"
+
\ No newline at end of file
diff --git a/src/src/app/build/intermediates/incremental/mergeDebugResources/merged.dir/values-night-v8/values-night-v8.xml b/src/src/app/build/intermediates/incremental/mergeDebugResources/merged.dir/values-night-v8/values-night-v8.xml
new file mode 100644
index 0000000..17a2110
--- /dev/null
+++ b/src/src/app/build/intermediates/incremental/mergeDebugResources/merged.dir/values-night-v8/values-night-v8.xml
@@ -0,0 +1,10 @@
+
+
+
+
+
+
+
+
+
+
\ No newline at end of file
diff --git a/src/src/app/build/intermediates/incremental/mergeDebugResources/merged.dir/values-nl/values-nl.xml b/src/src/app/build/intermediates/incremental/mergeDebugResources/merged.dir/values-nl/values-nl.xml
new file mode 100644
index 0000000..a231476
--- /dev/null
+++ b/src/src/app/build/intermediates/incremental/mergeDebugResources/merged.dir/values-nl/values-nl.xml
@@ -0,0 +1,32 @@
+
+
+ "Navigeren naar startpositie"
+ "Omhoog navigeren"
+ "Meer opties"
+ "Gereed"
+ "Alles weergeven"
+ "Een app selecteren"
+ "UIT"
+ "AAN"
+ "Alt +"
+ "Ctrl +"
+ "verwijderen"
+ "enter"
+ "Functie +"
+ "Meta +"
+ "Shift +"
+ "spatie"
+ "Sym +"
+ "Menu +"
+ "Zoeken…"
+ "Zoekopdracht wissen"
+ "Zoekopdracht"
+ "Zoeken"
+ "Zoekopdracht verzenden"
+ "Gesproken zoekopdracht"
+ "Delen met"
+ "Delen met %s"
+ "Samenvouwen"
+ "Zoeken"
+ "999+"
+
\ No newline at end of file
diff --git a/src/src/app/build/intermediates/incremental/mergeDebugResources/merged.dir/values-or/values-or.xml b/src/src/app/build/intermediates/incremental/mergeDebugResources/merged.dir/values-or/values-or.xml
new file mode 100644
index 0000000..80994f8
--- /dev/null
+++ b/src/src/app/build/intermediates/incremental/mergeDebugResources/merged.dir/values-or/values-or.xml
@@ -0,0 +1,32 @@
+
+
+ "ହୋମ୍ ପେଜ୍କୁ ନେଭିଗେଟ୍ କରନ୍ତୁ"
+ "ଉପରକୁ ନେଭିଗେଟ୍ କରନ୍ତୁ"
+ "ଅଧିକ ବିକଳ୍ପ"
+ "ହୋଇଗଲା"
+ "ସବୁ ଦେଖନ୍ତୁ"
+ "ଗୋଟିଏ ଆପ୍ ବାଛନ୍ତୁ"
+ "ଅଫ୍"
+ "ଅନ୍"
+ "Alt+"
+ "Ctrl+"
+ "ଡିଲିଟ୍"
+ "ଏଣ୍ଟର୍"
+ "Function+"
+ "Meta+"
+ "Shift+"
+ "ସ୍ପେସ୍"
+ "Sym+"
+ "ମେନୁ"
+ "ସର୍ଚ୍ଚ…"
+ "କ୍ୱେରୀ ଖାଲି କରନ୍ତୁ"
+ "ସର୍ଚ୍ଚ କ୍ୱେରୀ"
+ "ସର୍ଚ୍ଚ କରନ୍ତୁ"
+ "କ୍ୱେରୀ ଦାଖଲ କରନ୍ତୁ"
+ "ଭଏସ୍ ସର୍ଚ୍ଚ"
+ "ଏହାଙ୍କ ସହ ଶେୟାର୍ କରନ୍ତୁ"
+ "%s ସହ ଶେୟାର୍ କରନ୍ତୁ"
+ "ଛୋଟ କରନ୍ତୁ"
+ "ସର୍ଚ୍ଚ କରନ୍ତୁ"
+ "999+"
+
\ No newline at end of file
diff --git a/src/src/app/build/intermediates/incremental/mergeDebugResources/merged.dir/values-pa/values-pa.xml b/src/src/app/build/intermediates/incremental/mergeDebugResources/merged.dir/values-pa/values-pa.xml
new file mode 100644
index 0000000..8fde8f7
--- /dev/null
+++ b/src/src/app/build/intermediates/incremental/mergeDebugResources/merged.dir/values-pa/values-pa.xml
@@ -0,0 +1,32 @@
+
+
+ "ਹੋਮ \'ਤੇ ਜਾਓ"
+ "ਉੱਪਰ ਜਾਓ"
+ "ਹੋਰ ਚੋਣਾਂ"
+ "ਹੋ ਗਿਆ"
+ "ਸਭ ਦੇਖੋ"
+ "ਇੱਕ ਐਪ ਚੁਣੋ"
+ "ਬੰਦ"
+ "ਤੇ"
+ "Alt+"
+ "Ctrl+"
+ "delete"
+ "enter"
+ "Function+"
+ "Meta+"
+ "Shift+"
+ "space"
+ "Sym+"
+ "Menu+"
+ "ਖੋਜ…"
+ "ਸਵਾਲ ਹਟਾਓ"
+ "ਖੋਜ ਪੁੱਛਗਿੱਛ"
+ "ਖੋਜੋ"
+ "ਸਵਾਲ ਪ੍ਰਸਤੁਤ ਕਰੋ"
+ "ਵੌਇਸ ਖੋਜ"
+ "ਇਸ ਨਾਲ ਸਾਂਝਾ ਕਰੋ"
+ "%s ਨਾਲ ਸਾਂਝਾ ਕਰੋ"
+ "ਨਸ਼ਟ ਕਰੋ"
+ "ਖੋਜੋ"
+ "999+"
+
\ No newline at end of file
diff --git a/src/src/app/build/intermediates/incremental/mergeDebugResources/merged.dir/values-pl/values-pl.xml b/src/src/app/build/intermediates/incremental/mergeDebugResources/merged.dir/values-pl/values-pl.xml
new file mode 100644
index 0000000..a0e3c2b
--- /dev/null
+++ b/src/src/app/build/intermediates/incremental/mergeDebugResources/merged.dir/values-pl/values-pl.xml
@@ -0,0 +1,32 @@
+
+
+ "Przejdź do strony głównej"
+ "Przejdź wyżej"
+ "Więcej opcji"
+ "Gotowe"
+ "Zobacz wszystkie"
+ "Wybierz aplikację"
+ "WYŁ."
+ "WŁ."
+ "Alt+"
+ "Ctrl+"
+ "Delete"
+ "Enter"
+ "Funkcyjny+"
+ "Meta+"
+ "Shift+"
+ "spacja"
+ "Sym+"
+ "Menu+"
+ "Szukaj…"
+ "Wyczyść zapytanie"
+ "Wyszukiwane hasło"
+ "Szukaj"
+ "Wyślij zapytanie"
+ "Wyszukiwanie głosowe"
+ "Udostępnij dla"
+ "Udostępnij przez: %s"
+ "Zwiń"
+ "Szukaj"
+ "999+"
+
\ No newline at end of file
diff --git a/src/src/app/build/intermediates/incremental/mergeDebugResources/merged.dir/values-port/values-port.xml b/src/src/app/build/intermediates/incremental/mergeDebugResources/merged.dir/values-port/values-port.xml
new file mode 100644
index 0000000..7a925dc
--- /dev/null
+++ b/src/src/app/build/intermediates/incremental/mergeDebugResources/merged.dir/values-port/values-port.xml
@@ -0,0 +1,4 @@
+
+
+ false
+
\ No newline at end of file
diff --git a/src/src/app/build/intermediates/incremental/mergeDebugResources/merged.dir/values-pt-rBR/values-pt-rBR.xml b/src/src/app/build/intermediates/incremental/mergeDebugResources/merged.dir/values-pt-rBR/values-pt-rBR.xml
new file mode 100644
index 0000000..8178115
--- /dev/null
+++ b/src/src/app/build/intermediates/incremental/mergeDebugResources/merged.dir/values-pt-rBR/values-pt-rBR.xml
@@ -0,0 +1,32 @@
+
+
+ "Navegar para a página inicial"
+ "Navegar para cima"
+ "Mais opções"
+ "Concluído"
+ "Ver tudo"
+ "Selecione um app"
+ "DESATIVAR"
+ "ATIVAR"
+ "Alt+"
+ "Ctrl+"
+ "delete"
+ "enter"
+ "Function+"
+ "Meta+"
+ "Shift+"
+ "espaço"
+ "Sym+"
+ "Menu+"
+ "Pesquisar..."
+ "Limpar consulta"
+ "Consulta de pesquisa"
+ "Pesquisar"
+ "Enviar consulta"
+ "Pesquisa por voz"
+ "Compartilhar com"
+ "Compartilhar com %s"
+ "Recolher"
+ "Pesquisar"
+ "999+"
+
\ No newline at end of file
diff --git a/src/src/app/build/intermediates/incremental/mergeDebugResources/merged.dir/values-pt-rPT/values-pt-rPT.xml b/src/src/app/build/intermediates/incremental/mergeDebugResources/merged.dir/values-pt-rPT/values-pt-rPT.xml
new file mode 100644
index 0000000..185d95e
--- /dev/null
+++ b/src/src/app/build/intermediates/incremental/mergeDebugResources/merged.dir/values-pt-rPT/values-pt-rPT.xml
@@ -0,0 +1,32 @@
+
+
+ "Navegar para a página inicial"
+ "Navegar para cima"
+ "Mais opções"
+ "Concluído"
+ "Ver tudo"
+ "Escolher uma aplicação"
+ "DESATIVADO"
+ "ATIVADO"
+ "Alt +"
+ "Ctrl +"
+ "eliminar"
+ "enter"
+ "Função +"
+ "Meta +"
+ "Shift +"
+ "espaço"
+ "Sym +"
+ "Menu +"
+ "Pesquisar..."
+ "Limpar consulta"
+ "Consulta de pesquisa"
+ "Pesquisar"
+ "Enviar consulta"
+ "Pesquisa por voz"
+ "Partilhar com"
+ "Partilhar com a aplicação %s"
+ "Reduzir"
+ "Pesquisar"
+ "999+"
+
\ No newline at end of file
diff --git a/src/src/app/build/intermediates/incremental/mergeDebugResources/merged.dir/values-pt/values-pt.xml b/src/src/app/build/intermediates/incremental/mergeDebugResources/merged.dir/values-pt/values-pt.xml
new file mode 100644
index 0000000..8178115
--- /dev/null
+++ b/src/src/app/build/intermediates/incremental/mergeDebugResources/merged.dir/values-pt/values-pt.xml
@@ -0,0 +1,32 @@
+
+
+ "Navegar para a página inicial"
+ "Navegar para cima"
+ "Mais opções"
+ "Concluído"
+ "Ver tudo"
+ "Selecione um app"
+ "DESATIVAR"
+ "ATIVAR"
+ "Alt+"
+ "Ctrl+"
+ "delete"
+ "enter"
+ "Function+"
+ "Meta+"
+ "Shift+"
+ "espaço"
+ "Sym+"
+ "Menu+"
+ "Pesquisar..."
+ "Limpar consulta"
+ "Consulta de pesquisa"
+ "Pesquisar"
+ "Enviar consulta"
+ "Pesquisa por voz"
+ "Compartilhar com"
+ "Compartilhar com %s"
+ "Recolher"
+ "Pesquisar"
+ "999+"
+
\ No newline at end of file
diff --git a/src/src/app/build/intermediates/incremental/mergeDebugResources/merged.dir/values-ro/values-ro.xml b/src/src/app/build/intermediates/incremental/mergeDebugResources/merged.dir/values-ro/values-ro.xml
new file mode 100644
index 0000000..0cb538b
--- /dev/null
+++ b/src/src/app/build/intermediates/incremental/mergeDebugResources/merged.dir/values-ro/values-ro.xml
@@ -0,0 +1,32 @@
+
+
+ "Navigați la ecranul de pornire"
+ "Navigați în sus"
+ "Mai multe opțiuni"
+ "Terminat"
+ "Afișați-le pe toate"
+ "Alegeți o aplicație"
+ "DEZACTIVAȚI"
+ "ACTIVAT"
+ "Alt+"
+ "Ctrl+"
+ "delete"
+ "enter"
+ "Funcție+"
+ "Meta+"
+ "Shift+"
+ "spațiu"
+ "Sym+"
+ "Meniu+"
+ "Căutați…"
+ "Ștergeți interogarea"
+ "Interogare de căutare"
+ "Căutați"
+ "Trimiteți interogarea"
+ "Căutare vocală"
+ "Trimiteți la"
+ "Trimiteți folosind %s"
+ "Restrângeți"
+ "Căutați"
+ "999+"
+
\ No newline at end of file
diff --git a/src/src/app/build/intermediates/incremental/mergeDebugResources/merged.dir/values-ru/values-ru.xml b/src/src/app/build/intermediates/incremental/mergeDebugResources/merged.dir/values-ru/values-ru.xml
new file mode 100644
index 0000000..4f35028
--- /dev/null
+++ b/src/src/app/build/intermediates/incremental/mergeDebugResources/merged.dir/values-ru/values-ru.xml
@@ -0,0 +1,32 @@
+
+
+ "Перейти на главный экран"
+ "Перейти вверх"
+ "Другие параметры"
+ "Готово"
+ "Показать все"
+ "Выбрать приложение"
+ "ОТКЛ."
+ "ВКЛ."
+ "Alt +"
+ "Ctrl +"
+ "Delete"
+ "Ввод"
+ "Fn +"
+ "Meta +"
+ "Shift +"
+ "Пробел"
+ "Sym +"
+ "Меню +"
+ "Поиск"
+ "Удалить запрос"
+ "Поисковый запрос"
+ "Поиск"
+ "Отправить запрос"
+ "Голосовой поиск"
+ "Открыть доступ"
+ "Открыть доступ приложению \"%s\""
+ "Свернуть"
+ "Поиск"
+ "999+"
+
\ No newline at end of file
diff --git a/src/src/app/build/intermediates/incremental/mergeDebugResources/merged.dir/values-si/values-si.xml b/src/src/app/build/intermediates/incremental/mergeDebugResources/merged.dir/values-si/values-si.xml
new file mode 100644
index 0000000..2cdb338
--- /dev/null
+++ b/src/src/app/build/intermediates/incremental/mergeDebugResources/merged.dir/values-si/values-si.xml
@@ -0,0 +1,32 @@
+
+
+ "ගෙදරට සංචාලනය කරන්න"
+ "ඉහලට සංචාලනය කරන්න"
+ "තවත් විකල්ප"
+ "අවසාන වූ"
+ "සියල්ල බලන්න"
+ "යෙදුමක් තෝරන්න"
+ "ක්රියාවිරහිතයි"
+ "ක්රියාත්මකයි"
+ "Alt+"
+ "Ctrl+"
+ "මකන්න"
+ "enter"
+ "Function+"
+ "Meta+"
+ "Shift+"
+ "space"
+ "Sym+"
+ "Menu+"
+ "සොයන්න..."
+ "විමසුම හිස් කරන්න"
+ "සෙවුම් විමසුම"
+ "සෙවීම"
+ "විමසුම යොමු කරන්න"
+ "හඬ සෙවීම"
+ "සමඟ බෙදාගන්න"
+ "%s සමඟ බෙදා ගන්න"
+ "හකුළන්න"
+ "සොයන්න"
+ "999+"
+
\ No newline at end of file
diff --git a/src/src/app/build/intermediates/incremental/mergeDebugResources/merged.dir/values-sk/values-sk.xml b/src/src/app/build/intermediates/incremental/mergeDebugResources/merged.dir/values-sk/values-sk.xml
new file mode 100644
index 0000000..0d84abc
--- /dev/null
+++ b/src/src/app/build/intermediates/incremental/mergeDebugResources/merged.dir/values-sk/values-sk.xml
@@ -0,0 +1,32 @@
+
+
+ "Prejsť na plochu"
+ "Prejsť hore"
+ "Ďalšie možnosti"
+ "Hotovo"
+ "Zobraziť všetko"
+ "Zvoľte aplikáciu"
+ "VYPNUTÉ"
+ "ZAPNUTÉ"
+ "Alt+"
+ "Ctrl+"
+ "odstrániť"
+ "enter"
+ "Function+"
+ "Meta+"
+ "Shift+"
+ "medzerník"
+ "Sym+"
+ "Menu+"
+ "Vyhľadať…"
+ "Vymazať dopyt"
+ "Vyhľadávací dopyt"
+ "Hľadať"
+ "Odoslať dopyt"
+ "Hlasové vyhľadávanie"
+ "Zdieľať pomocou"
+ "Zdieľať s aplikáciou %s"
+ "Zbaliť"
+ "Vyhľadávanie"
+ "999+"
+
\ No newline at end of file
diff --git a/src/src/app/build/intermediates/incremental/mergeDebugResources/merged.dir/values-sl/values-sl.xml b/src/src/app/build/intermediates/incremental/mergeDebugResources/merged.dir/values-sl/values-sl.xml
new file mode 100644
index 0000000..86652ae
--- /dev/null
+++ b/src/src/app/build/intermediates/incremental/mergeDebugResources/merged.dir/values-sl/values-sl.xml
@@ -0,0 +1,32 @@
+
+
+ "Krmarjenje domov"
+ "Krmarjenje navzgor"
+ "Več možnosti"
+ "Končano"
+ "Pokaži vse"
+ "Izbira aplikacije"
+ "IZKLOPLJENO"
+ "VKLOPLJENO"
+ "Alt +"
+ "Ctrl +"
+ "Delete"
+ "Enter"
+ "Fn +"
+ "Meta +"
+ "Shift +"
+ "preslednica"
+ "Sym +"
+ "Meni +"
+ "Iskanje …"
+ "Izbris poizvedbe"
+ "Iskalna poizvedba"
+ "Iskanje"
+ "Pošiljanje poizvedbe"
+ "Glasovno iskanje"
+ "Deljenje z"
+ "Deljenje z drugimi prek aplikacije %s"
+ "Strni"
+ "Iskanje"
+ "999+"
+
\ No newline at end of file
diff --git a/src/src/app/build/intermediates/incremental/mergeDebugResources/merged.dir/values-sq/values-sq.xml b/src/src/app/build/intermediates/incremental/mergeDebugResources/merged.dir/values-sq/values-sq.xml
new file mode 100644
index 0000000..9e1578d
--- /dev/null
+++ b/src/src/app/build/intermediates/incremental/mergeDebugResources/merged.dir/values-sq/values-sq.xml
@@ -0,0 +1,32 @@
+
+
+ "Orientohu për në shtëpi"
+ "Ngjitu lart"
+ "Opsione të tjera"
+ "U krye!"
+ "Shikoji të gjitha"
+ "Zgjidh një aplikacion"
+ "JOAKTIV"
+ "AKTIV"
+ "Alt+"
+ "Ctrl+"
+ "delete"
+ "enter"
+ "Funksioni+"
+ "Meta+"
+ "Shift+"
+ "hapësirë"
+ "Sym+"
+ "Menyja+"
+ "Kërko..."
+ "Pastro pyetjen"
+ "Kërko pyetjen"
+ "Kërko"
+ "Dërgo pyetjen"
+ "Kërkim me zë"
+ "Shpërnda publikisht me"
+ "Ndaje me %s"
+ "Shpalos"
+ "Kërko"
+ "999+"
+
\ No newline at end of file
diff --git a/src/src/app/build/intermediates/incremental/mergeDebugResources/merged.dir/values-sr/values-sr.xml b/src/src/app/build/intermediates/incremental/mergeDebugResources/merged.dir/values-sr/values-sr.xml
new file mode 100644
index 0000000..91ae9af
--- /dev/null
+++ b/src/src/app/build/intermediates/incremental/mergeDebugResources/merged.dir/values-sr/values-sr.xml
@@ -0,0 +1,32 @@
+
+
+ "Одлазак на Почетну"
+ "Кретање нагоре"
+ "Још опција"
+ "Готово"
+ "Прикажи све"
+ "Избор апликације"
+ "ИСКЉУЧИ"
+ "УКЉУЧИ"
+ "Alt+"
+ "Ctrl+"
+ "delete"
+ "enter"
+ "Function+"
+ "Meta+"
+ "Shift+"
+ "тастер за размак"
+ "Sym+"
+ "Menu+"
+ "Претражите..."
+ "Брисање упита"
+ "Упит за претрагу"
+ "Претрага"
+ "Слање упита"
+ "Гласовна претрага"
+ "Дели са"
+ "Дељење са апликацијом %s"
+ "Скупи"
+ "Претражи"
+ "999+"
+
\ No newline at end of file
diff --git a/src/src/app/build/intermediates/incremental/mergeDebugResources/merged.dir/values-sv/values-sv.xml b/src/src/app/build/intermediates/incremental/mergeDebugResources/merged.dir/values-sv/values-sv.xml
new file mode 100644
index 0000000..3031a33
--- /dev/null
+++ b/src/src/app/build/intermediates/incremental/mergeDebugResources/merged.dir/values-sv/values-sv.xml
@@ -0,0 +1,32 @@
+
+
+ "Visa startsidan"
+ "Navigera uppåt"
+ "Fler alternativ"
+ "Klart"
+ "Visa alla"
+ "Välj en app"
+ "AV"
+ "PÅ"
+ "Alt + "
+ "Ctrl + "
+ "delete"
+ "retur"
+ "Funktion + "
+ "Meta + "
+ "Skift + "
+ "blanksteg"
+ "Symbol + "
+ "Meny + "
+ "Sök …"
+ "Ta bort frågan"
+ "Sökfråga"
+ "Sök"
+ "Skicka fråga"
+ "Röstsökning"
+ "Dela med"
+ "Dela med %s"
+ "Komprimera"
+ "Sök"
+ "999+"
+
\ No newline at end of file
diff --git a/src/src/app/build/intermediates/incremental/mergeDebugResources/merged.dir/values-sw/values-sw.xml b/src/src/app/build/intermediates/incremental/mergeDebugResources/merged.dir/values-sw/values-sw.xml
new file mode 100644
index 0000000..12b1378
--- /dev/null
+++ b/src/src/app/build/intermediates/incremental/mergeDebugResources/merged.dir/values-sw/values-sw.xml
@@ -0,0 +1,32 @@
+
+
+ "Nenda mwanzo"
+ "Nenda juu"
+ "Chaguo zaidi"
+ "Nimemaliza"
+ "Angalia zote"
+ "Chagua programu"
+ "IMEZIMWA"
+ "IMEWASHWA"
+ "Alt+"
+ "Ctrl+"
+ "futa"
+ "enter"
+ "Function+"
+ "Meta+"
+ "Shift+"
+ "nafasi"
+ "Sym+"
+ "Menyu+"
+ "Tafuta…"
+ "Futa hoja"
+ "Hoja ya utafutaji"
+ "Tafuta"
+ "Wasilisha hoja"
+ "Tafuta kwa kutamka"
+ "Shiriki na:"
+ "Shiriki ukitumia %s"
+ "Kunja"
+ "Tafuta"
+ "999+"
+
\ No newline at end of file
diff --git a/src/src/app/build/intermediates/incremental/mergeDebugResources/merged.dir/values-sw600dp-v13/values-sw600dp-v13.xml b/src/src/app/build/intermediates/incremental/mergeDebugResources/merged.dir/values-sw600dp-v13/values-sw600dp-v13.xml
new file mode 100644
index 0000000..be7c95f
--- /dev/null
+++ b/src/src/app/build/intermediates/incremental/mergeDebugResources/merged.dir/values-sw600dp-v13/values-sw600dp-v13.xml
@@ -0,0 +1,11 @@
+
+
+ 24dp
+ 80dp
+ 64dp
+ 8dp
+ 8dp
+ 580dp
+ 16dp
+ 20dp
+
\ No newline at end of file
diff --git a/src/src/app/build/intermediates/incremental/mergeDebugResources/merged.dir/values-ta/values-ta.xml b/src/src/app/build/intermediates/incremental/mergeDebugResources/merged.dir/values-ta/values-ta.xml
new file mode 100644
index 0000000..d9f29b6
--- /dev/null
+++ b/src/src/app/build/intermediates/incremental/mergeDebugResources/merged.dir/values-ta/values-ta.xml
@@ -0,0 +1,32 @@
+
+
+ "முகப்பிற்கு வழிசெலுத்து"
+ "மேலே செல்"
+ "மேலும் விருப்பங்கள்"
+ "முடிந்தது"
+ "எல்லாம் காட்டு"
+ "பயன்பாட்டைத் தேர்வுசெய்க"
+ "ஆஃப்"
+ "ஆன்"
+ "ஆல்ட் மற்றும்"
+ "கண்ட்ரோல் மற்றும்"
+ "டெலிட்"
+ "எண்டர்"
+ "ஃபங்ஷன் மற்றும்"
+ "மெட்டா மற்றும்"
+ "ஷிஃப்ட் மற்றும்"
+ "ஸ்பேஸ்"
+ "சிம்பல் மற்றும்"
+ "மெனு மற்றும்"
+ "தேடு..."
+ "வினவலை அழி"
+ "தேடல் வினவல்"
+ "தேடு"
+ "வினவலைச் சமர்ப்பி"
+ "குரல் தேடல்"
+ "இதனுடன் பகிர்"
+ "%s மூலம் பகிர்"
+ "சுருக்கு"
+ "தேடு"
+ "999+"
+
\ No newline at end of file
diff --git a/src/src/app/build/intermediates/incremental/mergeDebugResources/merged.dir/values-te/values-te.xml b/src/src/app/build/intermediates/incremental/mergeDebugResources/merged.dir/values-te/values-te.xml
new file mode 100644
index 0000000..54f0b16
--- /dev/null
+++ b/src/src/app/build/intermediates/incremental/mergeDebugResources/merged.dir/values-te/values-te.xml
@@ -0,0 +1,32 @@
+
+
+ "హోమ్కు నావిగేట్ చేయండి"
+ "పైకి నావిగేట్ చేయండి"
+ "మరిన్ని ఎంపికలు"
+ "పూర్తయింది"
+ "అన్నీ చూడండి"
+ "అనువర్తనాన్ని ఎంచుకోండి"
+ "ఆఫ్ చేయి"
+ "ఆన్ చేయి"
+ "Alt+"
+ "Ctrl+"
+ "delete"
+ "enter"
+ "Function+"
+ "Meta+"
+ "Shift+"
+ "స్పేస్"
+ "Sym+"
+ "Menu+"
+ "వెతుకు..."
+ "ప్రశ్నను క్లియర్ చేయి"
+ "ప్రశ్న శోధించండి"
+ "వెతుకు"
+ "ప్రశ్నని సమర్పించు"
+ "వాయిస్ శోధన"
+ "వీరితో భాగస్వామ్యం చేయి"
+ "%sతో భాగస్వామ్యం చేయండి"
+ "కుదించండి"
+ "వెతుకు"
+ "999+"
+
\ No newline at end of file
diff --git a/src/src/app/build/intermediates/incremental/mergeDebugResources/merged.dir/values-th/values-th.xml b/src/src/app/build/intermediates/incremental/mergeDebugResources/merged.dir/values-th/values-th.xml
new file mode 100644
index 0000000..13dc94e
--- /dev/null
+++ b/src/src/app/build/intermediates/incremental/mergeDebugResources/merged.dir/values-th/values-th.xml
@@ -0,0 +1,32 @@
+
+
+ "นำทางไปหน้าแรก"
+ "นำทางขึ้น"
+ "ตัวเลือกอื่น"
+ "เสร็จสิ้น"
+ "ดูทั้งหมด"
+ "เลือกแอป"
+ "ปิด"
+ "เปิด"
+ "Alt+"
+ "Ctrl+"
+ "Delete"
+ "Enter"
+ "Function+"
+ "Meta+"
+ "Shift+"
+ "Space"
+ "Sym+"
+ "เมนู+"
+ "ค้นหา…"
+ "ล้างข้อความค้นหา"
+ "ข้อความค้นหา"
+ "ค้นหา"
+ "ส่งข้อความค้นหา"
+ "ค้นหาด้วยเสียง"
+ "แชร์กับ"
+ "แชร์ทาง %s"
+ "ยุบ"
+ "ค้นหา"
+ "999+"
+
\ No newline at end of file
diff --git a/src/src/app/build/intermediates/incremental/mergeDebugResources/merged.dir/values-tl/values-tl.xml b/src/src/app/build/intermediates/incremental/mergeDebugResources/merged.dir/values-tl/values-tl.xml
new file mode 100644
index 0000000..18a148f
--- /dev/null
+++ b/src/src/app/build/intermediates/incremental/mergeDebugResources/merged.dir/values-tl/values-tl.xml
@@ -0,0 +1,32 @@
+
+
+ "Mag-navigate patungo sa home"
+ "Mag-navigate pataas"
+ "Higit pang mga opsyon"
+ "Tapos na"
+ "Tingnan lahat"
+ "Pumili ng isang app"
+ "I-OFF"
+ "I-ON"
+ "Alt+"
+ "Ctrl+"
+ "delete"
+ "enter"
+ "Function+"
+ "Meta+"
+ "Shift+"
+ "space"
+ "Sym+"
+ "Menu+"
+ "Maghanap…"
+ "I-clear ang query"
+ "Query sa paghahanap"
+ "Maghanap"
+ "Isumite ang query"
+ "Paghahanap gamit ang boses"
+ "Ibahagi sa/kay"
+ "Ibahagi gamit ang %s"
+ "I-collapse"
+ "Maghanap"
+ "999+"
+
\ No newline at end of file
diff --git a/src/src/app/build/intermediates/incremental/mergeDebugResources/merged.dir/values-tr/values-tr.xml b/src/src/app/build/intermediates/incremental/mergeDebugResources/merged.dir/values-tr/values-tr.xml
new file mode 100644
index 0000000..01b0f45
--- /dev/null
+++ b/src/src/app/build/intermediates/incremental/mergeDebugResources/merged.dir/values-tr/values-tr.xml
@@ -0,0 +1,32 @@
+
+
+ "Ana ekrana git"
+ "Yukarı git"
+ "Diğer seçenekler"
+ "Bitti"
+ "Tümünü göster"
+ "Bir uygulama seçin"
+ "KAPAT"
+ "AÇ"
+ "Alt+"
+ "Ctrl+"
+ "sil"
+ "enter"
+ "İşlev+"
+ "Meta+"
+ "Üst Karakter+"
+ "boşluk"
+ "Sym+"
+ "Menü+"
+ "Ara…"
+ "Sorguyu temizle"
+ "Arama sorgusu"
+ "Ara"
+ "Sorguyu gönder"
+ "Sesli arama"
+ "Şununla paylaş"
+ "%s ile paylaş"
+ "Daralt"
+ "Ara"
+ "999+"
+
\ No newline at end of file
diff --git a/src/src/app/build/intermediates/incremental/mergeDebugResources/merged.dir/values-uk/values-uk.xml b/src/src/app/build/intermediates/incremental/mergeDebugResources/merged.dir/values-uk/values-uk.xml
new file mode 100644
index 0000000..c1d3da7
--- /dev/null
+++ b/src/src/app/build/intermediates/incremental/mergeDebugResources/merged.dir/values-uk/values-uk.xml
@@ -0,0 +1,32 @@
+
+
+ "Перейти на головний"
+ "Перейти вгору"
+ "Інші опції"
+ "Готово"
+ "Переглянути всі"
+ "Вибрати програму"
+ "ВИМК."
+ "УВІМК."
+ "Alt+"
+ "Ctrl+"
+ "delete"
+ "enter"
+ "Function+"
+ "Meta+"
+ "Shift+"
+ "пробіл"
+ "Sym+"
+ "Menu+"
+ "Пошук…"
+ "Очистити запит"
+ "Пошуковий запит"
+ "Пошук"
+ "Надіслати запит"
+ "Голосовий пошук"
+ "Надіслати через"
+ "Поділитися через додаток %s"
+ "Згорнути"
+ "Пошук"
+ "999+"
+
\ No newline at end of file
diff --git a/src/src/app/build/intermediates/incremental/mergeDebugResources/merged.dir/values-ur/values-ur.xml b/src/src/app/build/intermediates/incremental/mergeDebugResources/merged.dir/values-ur/values-ur.xml
new file mode 100644
index 0000000..6b717f4
--- /dev/null
+++ b/src/src/app/build/intermediates/incremental/mergeDebugResources/merged.dir/values-ur/values-ur.xml
@@ -0,0 +1,32 @@
+
+
+ "ہوم پر نیویگیٹ کریں"
+ "اوپر نیویگیٹ کریں"
+ "مزید اختیارات"
+ "ہو گیا"
+ "سبھی دیکھیں"
+ "ایک ایپ منتخب کریں"
+ "آف"
+ "آن"
+ "Alt+"
+ "Ctrl+"
+ "delete"
+ "enter"
+ "Function+"
+ "Meta+"
+ "Shift+"
+ "space"
+ "Sym+"
+ "Menu+"
+ "تلاش کریں…"
+ "استفسار صاف کریں"
+ "استفسار تلاش کریں"
+ "تلاش کریں"
+ "استفسار جمع کرائیں"
+ "صوتی تلاش"
+ "اشتراک کریں مع"
+ "%s کے ساتھ اشتراک کریں"
+ "سکیڑیں"
+ "تلاش"
+ "+999"
+
\ No newline at end of file
diff --git a/src/src/app/build/intermediates/incremental/mergeDebugResources/merged.dir/values-uz/values-uz.xml b/src/src/app/build/intermediates/incremental/mergeDebugResources/merged.dir/values-uz/values-uz.xml
new file mode 100644
index 0000000..053764c
--- /dev/null
+++ b/src/src/app/build/intermediates/incremental/mergeDebugResources/merged.dir/values-uz/values-uz.xml
@@ -0,0 +1,32 @@
+
+
+ "Boshiga o‘tish"
+ "Yuqoriga o‘tish"
+ "Boshqa parametrlar"
+ "Tayyor"
+ "Hammasi"
+ "Dastur tanlang"
+ "O‘CHIQ"
+ "YONIQ"
+ "Alt+"
+ "Ctrl+"
+ "Delete"
+ "Enter"
+ "Fn+"
+ "Meta+"
+ "Shift+"
+ "Probel"
+ "Sym+"
+ "Menyu+"
+ "Qidirish…"
+ "So‘rovni tozalash"
+ "So‘rovni izlash"
+ "Qidirish"
+ "So‘rov yaratish"
+ "Ovozli qidiruv"
+ "Ruxsat berish"
+ "%s orqali ulashish"
+ "Yig‘ish"
+ "Qidirish"
+ "999+"
+
\ No newline at end of file
diff --git a/src/src/app/build/intermediates/incremental/mergeDebugResources/merged.dir/values-v16/values-v16.xml b/src/src/app/build/intermediates/incremental/mergeDebugResources/merged.dir/values-v16/values-v16.xml
new file mode 100644
index 0000000..5ee2feb
--- /dev/null
+++ b/src/src/app/build/intermediates/incremental/mergeDebugResources/merged.dir/values-v16/values-v16.xml
@@ -0,0 +1,8 @@
+
+
+ 4dp
+
+
\ No newline at end of file
diff --git a/src/src/app/build/intermediates/incremental/mergeDebugResources/merged.dir/values-v17/values-v17.xml b/src/src/app/build/intermediates/incremental/mergeDebugResources/merged.dir/values-v17/values-v17.xml
new file mode 100644
index 0000000..f85a197
--- /dev/null
+++ b/src/src/app/build/intermediates/incremental/mergeDebugResources/merged.dir/values-v17/values-v17.xml
@@ -0,0 +1,62 @@
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
\ No newline at end of file
diff --git a/src/src/app/build/intermediates/incremental/mergeDebugResources/merged.dir/values-v18/values-v18.xml b/src/src/app/build/intermediates/incremental/mergeDebugResources/merged.dir/values-v18/values-v18.xml
new file mode 100644
index 0000000..7dad77f
--- /dev/null
+++ b/src/src/app/build/intermediates/incremental/mergeDebugResources/merged.dir/values-v18/values-v18.xml
@@ -0,0 +1,4 @@
+
+
+ 0px
+
\ No newline at end of file
diff --git a/src/src/app/build/intermediates/incremental/mergeDebugResources/merged.dir/values-v21/values-v21.xml b/src/src/app/build/intermediates/incremental/mergeDebugResources/merged.dir/values-v21/values-v21.xml
new file mode 100644
index 0000000..35c74d5
--- /dev/null
+++ b/src/src/app/build/intermediates/incremental/mergeDebugResources/merged.dir/values-v21/values-v21.xml
@@ -0,0 +1,288 @@
+
+
+ @color/secondary_text_default_material_light
+ 0dp
+ 0dp
+ 12dp
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
\ No newline at end of file
diff --git a/src/src/app/build/intermediates/incremental/mergeDebugResources/merged.dir/values-v22/values-v22.xml b/src/src/app/build/intermediates/incremental/mergeDebugResources/merged.dir/values-v22/values-v22.xml
new file mode 100644
index 0000000..d4a514a
--- /dev/null
+++ b/src/src/app/build/intermediates/incremental/mergeDebugResources/merged.dir/values-v22/values-v22.xml
@@ -0,0 +1,15 @@
+
+
+
+
+
+
+
\ No newline at end of file
diff --git a/src/src/app/build/intermediates/incremental/mergeDebugResources/merged.dir/values-v23/values-v23.xml b/src/src/app/build/intermediates/incremental/mergeDebugResources/merged.dir/values-v23/values-v23.xml
new file mode 100644
index 0000000..d807aae
--- /dev/null
+++ b/src/src/app/build/intermediates/incremental/mergeDebugResources/merged.dir/values-v23/values-v23.xml
@@ -0,0 +1,38 @@
+
+
+
+
+
+
+
+
+
+
+
+
+
+
\ No newline at end of file
diff --git a/src/src/app/build/intermediates/incremental/mergeDebugResources/merged.dir/values-v24/values-v24.xml b/src/src/app/build/intermediates/incremental/mergeDebugResources/merged.dir/values-v24/values-v24.xml
new file mode 100644
index 0000000..dbae6fb
--- /dev/null
+++ b/src/src/app/build/intermediates/incremental/mergeDebugResources/merged.dir/values-v24/values-v24.xml
@@ -0,0 +1,9 @@
+
+
+
+
+
+
+
+
+
\ No newline at end of file
diff --git a/src/src/app/build/intermediates/incremental/mergeDebugResources/merged.dir/values-v25/values-v25.xml b/src/src/app/build/intermediates/incremental/mergeDebugResources/merged.dir/values-v25/values-v25.xml
new file mode 100644
index 0000000..483ae0c
--- /dev/null
+++ b/src/src/app/build/intermediates/incremental/mergeDebugResources/merged.dir/values-v25/values-v25.xml
@@ -0,0 +1,9 @@
+
+
+
+
+
+
+
\ No newline at end of file
diff --git a/src/src/app/build/intermediates/incremental/mergeDebugResources/merged.dir/values-v26/values-v26.xml b/src/src/app/build/intermediates/incremental/mergeDebugResources/merged.dir/values-v26/values-v26.xml
new file mode 100644
index 0000000..8b28a46
--- /dev/null
+++ b/src/src/app/build/intermediates/incremental/mergeDebugResources/merged.dir/values-v26/values-v26.xml
@@ -0,0 +1,18 @@
+
+
+
+
+
+
+
+
+
\ No newline at end of file
diff --git a/src/src/app/build/intermediates/incremental/mergeDebugResources/merged.dir/values-v28/values-v28.xml b/src/src/app/build/intermediates/incremental/mergeDebugResources/merged.dir/values-v28/values-v28.xml
new file mode 100644
index 0000000..e3801cd
--- /dev/null
+++ b/src/src/app/build/intermediates/incremental/mergeDebugResources/merged.dir/values-v28/values-v28.xml
@@ -0,0 +1,13 @@
+
+
+
+
+
+
+
\ No newline at end of file
diff --git a/src/src/app/build/intermediates/incremental/mergeDebugResources/merged.dir/values-vi/values-vi.xml b/src/src/app/build/intermediates/incremental/mergeDebugResources/merged.dir/values-vi/values-vi.xml
new file mode 100644
index 0000000..1eabc08
--- /dev/null
+++ b/src/src/app/build/intermediates/incremental/mergeDebugResources/merged.dir/values-vi/values-vi.xml
@@ -0,0 +1,32 @@
+
+
+ "Điều hướng về trang chủ"
+ "Điều hướng lên trên"
+ "Tùy chọn khác"
+ "Xong"
+ "Xem tất cả"
+ "Chọn một ứng dụng"
+ "TẮT"
+ "BẬT"
+ "Alt+"
+ "Ctrl+"
+ "delete"
+ "enter"
+ "Function+"
+ "Meta+"
+ "Shift+"
+ "phím cách"
+ "Sym+"
+ "Menu+"
+ "Tìm kiếm…"
+ "Xóa truy vấn"
+ "Tìm kiếm truy vấn"
+ "Tìm kiếm"
+ "Gửi truy vấn"
+ "Tìm kiếm bằng giọng nói"
+ "Chia sẻ với"
+ "Chia sẻ với %s"
+ "Thu gọn"
+ "Tìm kiếm"
+ "999+"
+
\ No newline at end of file
diff --git a/src/src/app/build/intermediates/incremental/mergeDebugResources/merged.dir/values-watch-v20/values-watch-v20.xml b/src/src/app/build/intermediates/incremental/mergeDebugResources/merged.dir/values-watch-v20/values-watch-v20.xml
new file mode 100644
index 0000000..2d85812
--- /dev/null
+++ b/src/src/app/build/intermediates/incremental/mergeDebugResources/merged.dir/values-watch-v20/values-watch-v20.xml
@@ -0,0 +1,12 @@
+
+
+
+
+
+
\ No newline at end of file
diff --git a/src/src/app/build/intermediates/incremental/mergeDebugResources/merged.dir/values-watch-v21/values-watch-v21.xml b/src/src/app/build/intermediates/incremental/mergeDebugResources/merged.dir/values-watch-v21/values-watch-v21.xml
new file mode 100644
index 0000000..deecc9e
--- /dev/null
+++ b/src/src/app/build/intermediates/incremental/mergeDebugResources/merged.dir/values-watch-v21/values-watch-v21.xml
@@ -0,0 +1,15 @@
+
+
+
+
+
+
\ No newline at end of file
diff --git a/src/src/app/build/intermediates/incremental/mergeDebugResources/merged.dir/values-xlarge-v4/values-xlarge-v4.xml b/src/src/app/build/intermediates/incremental/mergeDebugResources/merged.dir/values-xlarge-v4/values-xlarge-v4.xml
new file mode 100644
index 0000000..b499d2c
--- /dev/null
+++ b/src/src/app/build/intermediates/incremental/mergeDebugResources/merged.dir/values-xlarge-v4/values-xlarge-v4.xml
@@ -0,0 +1,9 @@
+
+
+ 60%
+ 90%
+ 50%
+ 70%
+ 45%
+ 72%
+
\ No newline at end of file
diff --git a/src/src/app/build/intermediates/incremental/mergeDebugResources/merged.dir/values-zh-rCN/values-zh-rCN.xml b/src/src/app/build/intermediates/incremental/mergeDebugResources/merged.dir/values-zh-rCN/values-zh-rCN.xml
new file mode 100644
index 0000000..aecbf36
--- /dev/null
+++ b/src/src/app/build/intermediates/incremental/mergeDebugResources/merged.dir/values-zh-rCN/values-zh-rCN.xml
@@ -0,0 +1,146 @@
+
+
+
+ 短信
+ 邮件
+
+
+ %1$s 条符合“%2$s”的搜索结果
+
+ "转到主屏幕"
+ "转到上一层级"
+ "更多选项"
+ "完成"
+ "查看全部"
+ "选择应用"
+ "关闭"
+ "开启"
+ "Alt+"
+ "Ctrl+"
+ "Delete 键"
+ "Enter 键"
+ "Fn+"
+ "Meta+"
+ "Shift+"
+ "空格键"
+ "Sym+"
+ "Menu+"
+ "搜索…"
+ "清除查询"
+ "搜索查询"
+ "搜索"
+ "提交查询"
+ "语音搜索"
+ "分享方式"
+ "使用%s分享"
+ "收起"
+ 确认删除文件夹及所包含的便签吗?
+ 确认要删除该条便签吗?
+ 确认要删除所选的 %d 条便签吗?
+ 删除
+ 便签
+ 便签2x2
+ 便签4x4
+ 删除
+ 通话便签
+ 插入图片
+ 取消
+ 设置
+ 采用默认手势
+ 成功删除提醒
+ 输入隐私密码
+ 手绘
+ 不能为空便签设置闹钟提醒
+ 不能将空便签发送到桌面
+ 要查看的便签不存在
+ 导出文本时发生错误,请检查SD卡
+ SD卡被占用,不能操作
+ 同步已取消
+ 同步失败,发生内部错误
+ 同步失败,请检查网络和帐号设置
+ 导出失败
+ 文件夹 %1$s 已存在,请重新命名
+ yyyyMMdd
+ MM月dd日 kk:mm
+ 已将文本文件(%1$s)输出至SD卡(%2$s)目录
+ 已将所选 %1$d 条便签移到 %2$s 文件夹
+ 请输入名称
+ 已添加到桌面
+ 撤销隐私便签
+ 设置为隐私便签
+ 提醒我
+ 显示目前便签数量
+ 新建文件夹
+ 删除
+ 取消全选
+ 导出文本
+ 修改文件夹名称
+ 刪除文件夹
+ 查看文件夹
+ 大
+ 正常
+ 文字大小
+ 小
+ 超大
+ 进入清单模式
+ 移动到文件夹
+ 上一级文件夹
+ 退出清单模式
+ 删除提醒
+ 搜索
+ 全选
+ 没有选中项,操作无效
+ 选中了 %d 项
+ 发送到桌面
+ 设置
+ 分享
+ 同步
+ 取消同步
+ 选择文件夹
+ 已过期
+ 发送邮件
+ 打开地图
+ 呼叫电话
+ 浏览网页
+ 查看
+ 知道了
+ 新建便签
+ ...
+ 与google task同步便签记录
+ 同步账号
+ 添加账号
+ 新建便签背景颜色随机
+ 取消同步
+ 立即同步
+ 当前帐号 %1$s
+ 如更换同步帐号,过去的帐号同步信息将被清空,再次切换的同时可能会造成数据重复
+ 请选择google帐号,便签将与该帐号的google task内容同步。
+ 同步便签
+ 上次同步于 %1$s
+ 取消
+ 更换账号
+ 删除账号
+ 设置
+ 正在同步中,不能修改同步帐号
+ 同步帐号已设置为%1$s
+ 便签
+ 搜索便签
+ 正在搜索便签
+ "搜索"
+ 便签中的文字
+ 采用自定义手势
+ 创建提醒
+ "999+"
+ 导出成功
+ 与%1$s同步成功
+ 正在获取服务器便签列表...
+ 登录%1$s...
+ 正在同步本地便签...
+ 打开相机
+ 同步已取消
+ 同步失败
+ 同步成功
+ 同步便签...
+ 没有关联内容,点击新建便签。
+ 访客模式下,便签内容不可见
+
\ No newline at end of file
diff --git a/src/src/app/build/intermediates/incremental/mergeDebugResources/merged.dir/values-zh-rHK/values-zh-rHK.xml b/src/src/app/build/intermediates/incremental/mergeDebugResources/merged.dir/values-zh-rHK/values-zh-rHK.xml
new file mode 100644
index 0000000..f533663
--- /dev/null
+++ b/src/src/app/build/intermediates/incremental/mergeDebugResources/merged.dir/values-zh-rHK/values-zh-rHK.xml
@@ -0,0 +1,32 @@
+
+
+ "瀏覽主頁"
+ "向上瀏覽"
+ "更多選項"
+ "完成"
+ "顯示全部"
+ "選擇應用程式"
+ "關閉"
+ "開啟"
+ "Alt +"
+ "Ctrl +"
+ "刪除"
+ "Enter 鍵"
+ "Fn +"
+ "Meta +"
+ "Shift +"
+ "空白鍵"
+ "Sym +"
+ "Menu +"
+ "搜尋…"
+ "清除查詢"
+ "搜尋查詢"
+ "搜尋"
+ "提交查詢"
+ "語音搜尋"
+ "分享對象"
+ "使用「%s」分享"
+ "收合"
+ "搜尋"
+ "999+"
+
\ No newline at end of file
diff --git a/src/src/app/build/intermediates/incremental/mergeDebugResources/merged.dir/values-zh-rTW/values-zh-rTW.xml b/src/src/app/build/intermediates/incremental/mergeDebugResources/merged.dir/values-zh-rTW/values-zh-rTW.xml
new file mode 100644
index 0000000..54b1dce
--- /dev/null
+++ b/src/src/app/build/intermediates/incremental/mergeDebugResources/merged.dir/values-zh-rTW/values-zh-rTW.xml
@@ -0,0 +1,36 @@
+
+
+
+ 短信
+ 郵件
+
+ "瀏覽首頁"
+ "向上瀏覽"
+ "更多選項"
+ "完成"
+ "查看全部"
+ "選擇應用程式"
+ "關閉"
+ "開啟"
+ "Alt +"
+ "Ctrl +"
+ "Delete 鍵"
+ "Enter 鍵"
+ "Fn +"
+ "Meta +"
+ "Shift +"
+ "空格鍵"
+ "Sym +"
+ "Menu +"
+ "搜尋…"
+ "清除查詢"
+ "搜尋查詢"
+ "搜尋"
+ "提交查詢"
+ "語音搜尋"
+ "選擇分享對象"
+ "與「%s」分享"
+ "收合"
+ "搜尋"
+ "999+"
+
\ No newline at end of file
diff --git a/src/src/app/build/intermediates/incremental/mergeDebugResources/merged.dir/values-zu/values-zu.xml b/src/src/app/build/intermediates/incremental/mergeDebugResources/merged.dir/values-zu/values-zu.xml
new file mode 100644
index 0000000..31e318d
--- /dev/null
+++ b/src/src/app/build/intermediates/incremental/mergeDebugResources/merged.dir/values-zu/values-zu.xml
@@ -0,0 +1,32 @@
+
+
+ "Zulazulela ekhaya"
+ "Zulazulela phezulu"
+ "Izinketho eziningi"
+ "Kwenziwe"
+ "Buka konke"
+ "Khetha uhlelo lokusebenza"
+ "VALIWE"
+ "VULIWE"
+ "Alt+"
+ "Ctrl+"
+ "susa"
+ "enter"
+ "Function+"
+ "Meta+"
+ "Shift+"
+ "space"
+ "Sym+"
+ "Imenyu+"
+ "Iyasesha..."
+ "Sula inkinga"
+ "Umbuzo wosesho"
+ "Sesha"
+ "Hambisa umbuzo"
+ "Ukusesha ngezwi"
+ "Yabelana no-"
+ "Yabelana ne-%s"
+ "Goqa"
+ "Sesha"
+ "999+"
+
\ No newline at end of file
diff --git a/src/src/app/build/intermediates/incremental/mergeDebugResources/merged.dir/values/values.xml b/src/src/app/build/intermediates/incremental/mergeDebugResources/merged.dir/values/values.xml
new file mode 100644
index 0000000..b41b463
--- /dev/null
+++ b/src/src/app/build/intermediates/incremental/mergeDebugResources/merged.dir/values/values.xml
@@ -0,0 +1,3278 @@
+
+
+
+ -%s
+ --%s
+ --%s
+ --%s
+
+
+ Messaging
+ Email
+
+
+
+
+
+
+ true
+ false
+ true
+ @android:color/black
+ #7fa87f
+ @android:color/black
+ @android:color/black
+ @color/material_deep_teal_200
+ @color/material_deep_teal_500
+ @color/material_grey_800
+ @android:color/white
+ @color/material_grey_850
+ @color/material_grey_50
+ #80ffffff
+ #80000000
+ @color/bright_foreground_material_light
+ @color/bright_foreground_material_dark
+ @android:color/white
+ @android:color/black
+ #ff5a595b
+ #ffd6d7d7
+ #80bebebe
+ #80323232
+ #ffbebebe
+ #ff323232
+ #ff7043
+ #ff5722
+ @android:color/white
+ @android:color/black
+ #6680cbc4
+ #66009688
+ #ff37474f
+ #ff263238
+ #ff21272b
+ #ff80cbc4
+ #ff009688
+ #fff5f5f5
+ #ffe0e0e0
+ #fffafafa
+ #ff757575
+ #ff424242
+ #ff303030
+ #ff212121
+ #ffffffff
+ #ff9e9e9e
+ #ff424242
+ @android:color/black
+ @color/material_grey_600
+ @color/material_grey_900
+ @color/material_grey_100
+ #ffffffff
+ #de000000
+ #4Dffffff
+ #39000000
+ #33ffffff
+ #1f000000
+ #b3ffffff
+ #8a000000
+ #36ffffff
+ #24000000
+ #ff616161
+ #ffbdbdbd
+ #ffbdbdbd
+ #fff1f1f1
+ #e6616161
+ #e6FFFFFF
+ #335b5b5b
+ 16dp
+ 72dp
+ 56dp
+ 0dp
+ 0dp
+ 4dp
+ 16dp
+ 10dp
+ 6dp
+ 48dp
+ 180dp
+ 5dp
+ -3dp
+ 48dp
+ 48dp
+ 36dp
+ 48dp
+ 48dp
+ @dimen/abc_control_inset_material
+ 6dp
+ 8dp
+ @dimen/abc_control_padding_material
+ 720dp
+ 320dp
+ 2dp
+ 4dp
+ 4dp
+ 2dp
+ 80%
+ 100%
+ 320dp
+ 320dp
+ 8dp
+ 8dp
+ 65%
+ 95%
+ 24dp
+ 18dp
+ 8dp
+ 0.30
+ 0.26
+ 32dip
+ 8dip
+ 8dip
+ 7dp
+ 4dp
+ 10dp
+ 16dp
+ @dimen/abc_action_bar_content_inset_material
+ 296dp
+ 4dp
+ 48dip
+ 320dip
+ 2dp
+ 2dp
+ 20dp
+ 3dp
+ 14sp
+ 14sp
+ 14sp
+ 12sp
+ 34sp
+ 45sp
+ 56sp
+ 112sp
+ 24sp
+ 22sp
+ 18sp
+ 14sp
+ 16sp
+ 14sp
+ 16sp
+ 16dp
+ 20sp
+ 20dp
+ 4dp
+ 6dp
+ 8dp
+ 4dp
+ 2dp
+ 320dp
+ 320dp
+ 0.30
+ 0.26
+ 0.26
+ 0.20
+ 0.12
+ 0.50
+ 0.38
+ 0.70
+ 0.54
+ 32dp
+ 13sp
+ 12dp
+ 8dp
+ 64dp
+ 64dp
+ 10dp
+ @dimen/notification_content_margin_start
+ 16dp
+ 2dp
+ 3dp
+ 24dp
+ 13sp
+ 10dp
+ 5dp
+ 2dp
+ 2dp
+ 2dp
+ 2dp
+ 26sp
+ 20sp
+ 17sp
+ 14sp
+ 33sp
+ 2dp
+ 16dp
+ 8dp
+ 8dp
+ 96dp
+ 6.5dp
+ 0dp
+ 16dp
+ #3333B5E5
+ #0cffffff
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ 220
+ 150
+ 127
+ 150
+ 999
+
+ %1$s result for \"%2$s\"
+
+ %1$s results for \"%2$s\"
+
+ Navigate home
+ Navigate up
+ More options
+ Done
+ See all
+ Choose an app
+ OFF
+ ON
+ sans-serif
+ sans-serif-medium
+ sans-serif-medium
+ sans-serif
+ sans-serif
+ sans-serif
+ sans-serif
+ sans-serif-light
+ sans-serif
+ sans-serif
+ sans-serif
+ sans-serif-medium
+ Alt+
+ Ctrl+
+ delete
+ enter
+ Function+
+ Meta+
+ Shift+
+ space
+ Sym+
+ Menu+
+ Search…
+ Clear query
+ Search query
+ Search
+ Submit query
+ Voice search
+ Share with
+ Share with %s
+ Collapse
+ Confirm to delete folder and its notes?
+ Confirm to delete this note?
+ Confirm to delete the selected %d notes?
+ Delete selected notes
+ Notes
+ Notes 2x2
+ Notes 4x4
+ Delete
+ Call notes
+ open the album
+ cancel
+ set
+ switch to default gestrue
+ Delete reminder successfully
+ Please input PassWord
+ start draw
+ Sorry, can not set clock on empty note
+ Sorry, can not send and empty note to home
+ The note is not exist
+ Export failed, please check SD card
+ SD card busy, not available now
+ Sync is canceled
+ Sync failed, internal error occurs
+ Sync failed, please check network and account settings
+ Export fail
+ notes_%s.txt
+ /MIUI/notes/
+ The folder %1$s exist, please rename
+ yyyyMMdd
+ MMMd kk:mm
+ Export text file (%1$s) to SD (%2$s) directory
+ (%d)
+ Have moved selected %1$d notes to %2$s folder
+ Input name
+ Note added to home
+ delete private mode
+ set private mode
+ Remind me
+ count how many notes are there
+ New Folder
+ Delete
+ Deselect all
+ Export text
+ Change folder name
+ Delete folder
+ View folder
+ Large
+ Medium
+ Font size
+ Small
+ Super
+ Enter check list
+ Move to folder
+ Parent folder
+ Leave check list
+ Delete reminder
+ Search
+ Select all
+ Nothing selected, the operation is invalid
+ %d selected
+ Send to home
+ Settings
+ Share
+ Sync
+ Cancel syncing
+ Select folder
+ Expired
+ Send email
+ Open map
+ Call
+ Browse web
+ Take a look
+ Got it
+ Add note
+ ...
+ Sync notes with google task
+ Sync account
+ Add account
+ New note background color random
+ Cancel syncing
+ Sync immediately
+ Current account %1$s
+ All sync related information will be deleted, which may result in duplicated items sometime
+ Please select a google account. Local notes will be synced with google task.
+ Sync notes
+ Last sync time %1$s
+ yyyy-MM-dd hh:mm:ss
+ Cancel
+ Change sync account
+ Remove sync account
+ Settings
+ Cannot change the account because sync is in progress
+ %1$s has been set as the sync account
+ Notes
+ Search notes
+ Searching Notes
+ Search
+ Text in your notes
+ set gestrue
+ Set reminder
+ 999+
+ Export successful
+ Sync is successful with account %1$s
+ Getting remote note list...
+ Logging into %1$s...
+ Synchronize local notes with Google Task...
+ take photo
+ Sync is canceled
+ Sync is failed
+ Sync is successful
+ Syncing notes...
+ No associated note found, click to create associated note.
+ Privacy mode,can not see note content
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
\ No newline at end of file
diff --git a/src/src/app/build/intermediates/incremental/mergeDebugResources/merger.xml b/src/src/app/build/intermediates/incremental/mergeDebugResources/merger.xml
new file mode 100644
index 0000000..2ac1231
--- /dev/null
+++ b/src/src/app/build/intermediates/incremental/mergeDebugResources/merger.xml
@@ -0,0 +1,3744 @@
+
+#ffffffff#ff9e9e9e#1f000000#8a000000
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ 4dp6dp8dp4dp2dp320dp320dp32dp13sp12dp8dp64dp64dp10dp@dimen/notification_content_margin_start16dp2dp3dp24dp13sp10dp5dp#3333B5E5#0cffffff999999+"999+""999+""999+""৯৯৯+""999+""999+""999+""999+""৯৯৯+""999+""999+""999+""999+""999+""999+""999+""999+""999+""999+""999+""+999""999+""999+""999+""999+""999+""999+""999+"">999""999+""999+""999+""999+""999+""999+""999+""999+""999+""999+""999+""999+""999+""999+""999+""999+""999+""999+""999+""999+""999+""999+""९९९+""999+""၉၉၉+""999+""९९९+""999+""999+""999+""999+""999+""999+""999+""999+""999+""999+""999+""999+""999+""999+""999+""999+""999+""999+""999+""999+""999+""999+""+999""999+"4dp@color/secondary_text_default_material_light0dp0dp12dp"999+""999+""999+""999+""999+"
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ #ff424242#ffffffff#b3ffffff2dp2dp2dp2dp127truefalsetrue@android:color/black#7fa87f@android:color/black@android:color/black@color/material_deep_teal_200@color/material_deep_teal_500@color/material_grey_800@android:color/white@color/material_grey_850@color/material_grey_50#80ffffff#80000000@color/bright_foreground_material_light@color/bright_foreground_material_dark@android:color/white@android:color/black#ff5a595b#ffd6d7d7#80bebebe#80323232#ffbebebe#ff323232#ff7043#ff5722@android:color/white@android:color/black#6680cbc4#66009688#ff37474f#ff263238#ff21272b#ff80cbc4#ff009688#fff5f5f5#ffe0e0e0#fffafafa#ff757575#ff424242#ff303030#ff212121@android:color/black@color/material_grey_600@color/material_grey_900@color/material_grey_100#ffffffff#de000000#4Dffffff#39000000#33ffffff#1f000000#b3ffffff#8a000000#36ffffff#24000000#ff616161#ffbdbdbd#ffbdbdbd#fff1f1f1#e6616161#e6FFFFFF
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ 16dp72dp56dp0dp0dp4dp16dp10dp6dp48dp180dp5dp-3dp48dp48dp36dp48dp48dp@dimen/abc_control_inset_material6dp8dp@dimen/abc_control_padding_material720dp320dp2dp4dp4dp2dp80%100%320dp320dp8dp8dp65%95%24dp18dp8dp0.300.2632dip8dip8dip7dp4dp10dp16dp@dimen/abc_action_bar_content_inset_material296dp4dp48dip320dip2dp2dp20dp3dp14sp14sp14sp12sp34sp45sp56sp112sp24sp22sp18sp14sp16sp14sp16sp16dp20sp20dp0.300.260.260.200.120.500.380.700.542dp16dp8dp8dp96dp6.5dp0dp16dp220150127150Navigate homeNavigate upMore optionsDoneSee allChoose an appOFFONsans-serifsans-serif-mediumsans-serif-mediumsans-serifsans-serifsans-serifsans-serifsans-serif-lightsans-serifsans-serifsans-serifsans-serif-mediumAlt+Ctrl+deleteenterFunction+Meta+Shift+spaceSym+Menu+Search…Clear querySearch querySearchSubmit queryVoice searchShare withShare with %sCollapseSearch"Navigeer tuis""Navigeer op""Nog opsies""Klaar""Sien alles""Kies \'n program""AF""AAN""Alt+""Ctrl+""delete""enter""Funksie+""Meta+""Shift+""spasiebalk""Simbool+""Kieslys+""Soek …""Vee navraag uit""Soeknavraag""Soek""Dien navraag in""Stemsoektog""Deel met""Deel met %s""Vou in""Soek""ወደ መነሻ ይዳስሱ""ወደ ላይ ይዳስሱ""ተጨማሪ አማራጮች""ተከናውኗል""ሁሉንም ይመልከቱ""መተግበሪያ ይምረጡ""ጠፍቷል""በርቷል""Alt+""Ctrl+""ሰርዝ""enter""Function+""Meta+""Shift+""space""Sym+""ምናሌ+""ፈልግ…""መጠይቅ አጽዳ""የፍለጋ ጥያቄ""ፍለጋ""መጠይቅ ያስረክቡ""የድምፅ ፍለጋ""ከሚከተለው ጋር ያጋሩ""ከ%s ጋር አጋራ""ሰብስብ""ፈልግ""التنقل إلى الشاشة الرئيسية""التنقل إلى أعلى""خيارات إضافية""تم""عرض الكل""اختيار تطبيق""إيقاف""تشغيل""Alt+""Ctrl+""delete""enter""Function+""Meta+""Shift+""space""Sym+""القائمة+""بحث…""محو طلب البحث""طلب البحث""بحث""إرسال طلب البحث""البحث الصوتي""مشاركة مع""مشاركة مع %s""تصغير""البحث""গৃহ পৃষ্ঠালৈ যাওক""ওপৰলৈ যাওক""অধিক বিকল্প""সম্পন্ন কৰা হ\'ল""সকলো চাওক""এটা এপ্ বাছনি কৰক""অফ কৰক""অন কৰক""Alt+""CTRL+""মচক""এণ্টাৰ""ফাংশ্বন+""মেটা+""শ্বিফ্ট+""স্পেচ""Sym+""মেনু+""অনুসন্ধান কৰক…""প্ৰশ্ন মচক""সন্ধান কৰিব খোজা প্ৰশ্ন""সন্ধান কৰক""প্ৰশ্ন দাখিল কৰক""কণ্ঠধ্বনিৰ যোগেৰে সন্ধান কৰক""ইয়াৰ জৰিয়তে শ্বেয়াৰ কৰক""%sৰ জৰিয়তে শ্বেয়াৰ কৰক""সংকুচিত কৰক""অনুসন্ধান কৰক""Evə naviqasiya et""Yuxarı get""Digər variantlar""Hazırdır""Hamısına baxın""Tətbiq seçin""DEAKTİV""AKTİV""Alt+""Ctrl+""silin""daxil olun""Funksiya+""Meta+""Shift+""kosmos""Sym+""Menyu+""Axtarış...""Sorğunu təmizlə""Axtarış sorğusu""Axtarış""Sorğunu göndərin""Səsli axtarış""Bununla paylaşın""%s ilə paylaşın""Yığışdırın""Axtarış""Odlazak na Početnu""Kretanje nagore""Još opcija""Gotovo""Prikaži sve""Izbor aplikacije""ISKLJUČI""UKLJUČI""Alt+""Ctrl+""delete""enter""Function+""Meta+""Shift+""taster za razmak""Sym+""Menu+""Pretražite...""Brisanje upita""Upit za pretragu""Pretraga""Slanje upita""Glasovna pretraga""Deli sa""Deljenje sa aplikacijom %s""Skupi""Pretraži""Перайсці на галоўную старонку""Перайсці ўверх""Дадатковыя параметры""Гатова""Прагледзець усё""Выбраць праграму""ВЫКЛ.""УКЛ.""Alt +""Ctrl +""Delete""Enter""Fn +""Meta +""Shift +""Прабел""Sym +""Меню +""Пошук...""Выдалiць запыт""Запыт на пошук""Пошук""Адправіць запыт""Галасавы пошук""Абагуліць з""Абагуліць праз праграму %s""Згарнуць""Пошук""Придвижване към „Начало“""Придвижване нагоре""Още опции""Готово""Вижте всички""Изберете приложение""ИЗКЛ.""ВКЛ.""Alt+""Ctrl+""delete""enter""Function+""Meta+""Shift+""клавиша за интервал""Sym+""Menu+""Търсете…""Изчистване на заявката""Заявка за търсене""Търсене""Изпращане на заявката""Гласово търсене""Споделяне със:""Споделяне със: %s""Свиване""Търсене""হোম এ নেভিগেট করুন""উপরের দিকে নেভিগেট করুন""আরও বিকল্প""সম্পন্ন হয়েছে""সবগুলো দেখুন""একটি অ্যাপ্লিকেশান বেছে নিন""বন্ধ""চালু""Alt+""Ctrl+""মুছুন""enter""Function+""Meta+""Shift+""স্পেস""Sym+""মেনু+""অনুসন্ধান...""ক্যোয়ারী সাফ করুন""ক্যোয়ারী খুঁজুন""খুঁজুন""ক্যোয়ারী জমা দিন""ভয়েস অনুসন্ধান""এর সাথে শেয়ার করুন""%s এর সাথে শেয়ার করুন""সঙ্কুচিত করুন""খুঁজুন""Vrati se na početnu stranicu""Navigiraj prema gore""Više opcija""Gotovo""Prikaži sve""Odaberite aplikaciju""ISKLJUČI""UKLJUČI""Alt+""Ctrl+""delete""enter""Function+""Meta+""Shift+""razmaknica""Sym+""Menu+""Pretraži...""Obriši upit""Pretraži upit""Traži""Pošalji upit""Glasovno pretraživanje""Dijeli sa""Dijeli koristeći aplikaciju %s""Skupi""Pretraži""Navega a la pàgina d\'inici""Navega cap a dalt""Més opcions""Fet""Mostra\'ls tots""Selecciona una aplicació""DESACTIVAT""ACTIVAT""Alt+""Ctrl+""Supr""Retorn""Funció+""Meta+""Maj+""Espai""Sym+""Menú+""Cerca...""Esborra la consulta""Consulta de cerca""Cerca""Envia la consulta""Cerca per veu""Comparteix amb""Comparteix amb %s""Replega""Cerca""Přejít na plochu""Přejít nahoru""Více možností""Hotovo""Zobrazit vše""Vybrat aplikaci""VYPNUTO""ZAPNUTO""Alt+""Ctrl+""delete""enter""Fn+""Meta+""Shift+""mezerník""Sym+""Menu+""Vyhledat…""Smazat dotaz""Vyhledávací dotaz""Hledat""Odeslat dotaz""Hlasové vyhledávání""Sdílet pomocí""Sdílet s aplikací %s""Sbalit""Hledat""Naviger hjem""Naviger op""Flere muligheder""Luk""Se alle""Vælg en app""FRA""TIL""Alt+""Ctrl+""delete""enter""Fn+""Meta+""Shift+""mellemrum""Sym+""Menu+""Søg…""Ryd forespørgslen""Søgeforespørgsel""Søg""Indsend forespørgslen""Talesøgning""Del med""Del med %s""Skjul""Søg""Zur Startseite""Nach oben""Weitere Optionen""Fertig""Alle ansehen""App auswählen""Aus""An""Alt +""Strg +""Löschen""Eingabetaste""Funktionstaste +""Meta-Taste +""Umschalttaste +""Leertaste +""Sym-Taste +""Menütaste +""Suchen…""Suchanfrage löschen""Suchanfrage""Suchen""Suchanfrage senden""Sprachsuche""Freigeben für""Mit %s teilen""Minimieren""Suchen""Πλοήγηση στην αρχική σελίδα""Πλοήγηση προς τα επάνω""Περισσότερες επιλογές""Τέλος""Προβολή όλων""Επιλέξτε κάποια εφαρμογή""ΑΠΕΝΕΡΓΟΠΟΙΗΣΗ""ΕΝΕΡΓΟΠΟΙΗΣΗ""Alt+""Ctrl+""delete""enter""Function+""Meta+""Shift+""διάστημα""Sym+""Menu+""Αναζήτηση…""Διαγραφή ερωτήματος""Ερώτημα αναζήτησης""Αναζήτηση""Υποβολή ερωτήματος""Φωνητική αναζήτηση""Κοινή χρήση με""Κοινή χρήση με %s""Σύμπτυξη""Αναζήτηση""Navigate home""Navigate up""More options""Done""See all""Choose an app""OFF""ON""Alt+""Ctrl+""delete""enter""Function+""Meta+""Shift+""space""Sym+""Menu+""Search…""Clear query""Search query""Search""Submit query""Voice search""Share with""Share with %s""Collapse""Search""Navigate home""Navigate up""More options""Done""See all""Choose an app""OFF""ON""Alt+""Ctrl+""delete""enter""Function+""Meta+""Shift+""space""Sym+""Menu+""Search…""Clear query""Search query""Search""Submit query""Voice search""Share with""Share with %s""Collapse""Search""Navigate home""Navigate up""More options""Done""See all""Choose an app""OFF""ON""Alt+""Ctrl+""delete""enter""Function+""Meta+""Shift+""space""Sym+""Menu+""Search…""Clear query""Search query""Search""Submit query""Voice search""Share with""Share with %s""Collapse""Search""Navigate home""Navigate up""More options""Done""See all""Choose an app""OFF""ON""Alt+""Ctrl+""delete""enter""Function+""Meta+""Shift+""space""Sym+""Menu+""Search…""Clear query""Search query""Search""Submit query""Voice search""Share with""Share with %s""Collapse""Search""Navigate home""Navigate up""More options""Done""See all""Choose an app""OFF""ON""Alt+""Ctrl+""delete""enter""Function+""Meta+""Shift+""space""Sym+""Menu+""Search…""Clear query""Search query""Search""Submit query""Voice search""Share with""Share with %s""Collapse""Search""Ir a la pantalla de inicio""Desplazarse hacia arriba""Más opciones""Listo""Ver todo""Seleccionar una aplicación""DESACTIVADO""ACTIVADO""Alt +""Ctrl +""Eliminar""Intro""Función +""Meta +""Mayús +""Espacio""Sym +""Menú +""Buscar…""Borrar consulta""Consulta""Buscar""Enviar consulta""Búsqueda por voz""Compartir con""Compartir con %s""Contraer""Buscar""Navegar a la página principal""Navegar hacia arriba""Más opciones""Listo""Ver todo""Elige una aplicación.""DESACTIVADO""ACTIVADO""Alt+""Ctrl+""borrar""intro""Función+""Meta+""Mayúscula+""espacio""Sym+""Menú+""Buscar…""Eliminar la consulta""Búsqueda""Búsqueda""Enviar consulta""Búsqueda por voz""Compartir con""Compartir con %s""Contraer""Buscar""Navigeerimine avaekraanile""Navigeerimine üles""Rohkem valikuid""Valmis""Kuva kõik""Valige rakendus""VÄLJAS""SEES""Alt +""Ctrl +""kustutamisklahv""sisestusklahv""Funktsiooniklahv +""Meta +""Tõstuklahv +""tühik""Sym +""Menüü +""Otsige …""Päringu tühistamine""Otsingupäring""Otsing""Päringu esitamine""Häälotsing""Jagamine:""Jagamine rakendusega %s""Ahendamine""Otsing""Joan orri nagusira""Joan gora""Aukera gehiago""Eginda""Ikusi guztiak""Aukeratu aplikazio bat""DESAKTIBATUTA""AKTIBATUTA""Alt +""Ktrl +""Ezabatu""Sartu""Funtzioa +""Meta +""Maius +""Zuriunea""Sym +""Menua +""Bilatu…""Garbitu kontsulta""Bilaketa-kontsulta""Bilatu""Bidali kontsulta""Ahozko bilaketa""Partekatu hauekin""Partekatu %s aplikazioarekin""Tolestu""Bilatu""پیمایش به صفحه اصلی""پیمایش به بالا""گزینههای بیشتر""تمام""مشاهده همه""انتخاب برنامه""خاموش""روشن""Alt+""Ctrl+""delete""enter""Function+""Meta+""Shift+""کلید فاصله""Sym+""منو+""جستجو…""پاک کردن عبارت جستجو""عبارت جستجو""جستجو""ارسال عبارت جستجو""جستجوی گفتاری""اشتراکگذاری با""اشتراکگذاری با %s""کوچک کردن""جستجو""Siirry etusivulle""Siirry ylös""Lisää""Valmis""Näytä kaikki""Valitse sovellus""POIS KÄYTÖSTÄ""KÄYTÖSSÄ""Alt+""Ctrl+""delete""enter""Fn+""Meta+""Vaihto+""välilyönti""Sym+""Valikko+""Haku…""Tyhjennä kysely""Hakulauseke""Haku""Lähetä kysely""Puhehaku""Jakaminen:""Jaa sovelluksessa %s""Kutista""Haku""Revenir à l\'accueil""Revenir en haut de la page""Plus d\'options""OK""Tout afficher""Sélectionner une application""DÉSACTIVÉ""ACTIVÉ""Alt+""Ctrl+""supprimer""entrée""Fonction+""Méta+""Maj+""espace""Sym+""Menu+""Rechercher…""Effacer la requête""Requête de recherche""Rechercher""Envoyer la requête""Recherche vocale""Partager avec""Partager avec %s""Réduire""Rechercher""Revenir à l\'accueil""Revenir en haut de la page""Plus d\'options""Terminé""Voir toutes les chaînes""Sélectionnez une application""DÉSACTIVÉ""ACTIVÉ""Alt+""Ctrl+""supprimer""entrée""Fonction+""Méta+""Maj+""espace""Sym+""Menu+""Recherche en cours...""Effacer la requête""Requête de recherche""Rechercher""Envoyer la requête""Recherche vocale""Partager""Partager avec %s""Réduire""Rechercher""Ir á páxina de inicio""Desprazarse cara arriba""Máis opcións""Feito""Ver todas""Escoller unha aplicación""DESACTIVAR""ACTIVAR""Alt +""Ctrl +""eliminar""Intro""Función +""Meta +""Maiús +""espazo""Sim +""Menú +""Buscar…""Borrar consulta""Consulta de busca""Buscar""Enviar consulta""Busca por voz""Compartir con""Compartir con %s""Contraer""Buscar""હોમ પર નેવિગેટ કરો""ઉપર નૅવિગેટ કરો""વધુ વિકલ્પો""થઈ ગયું""બધું જુઓ""એક ઍપ્લિકેશન પસંદ કરો""બંધ""ચાલુ""Alt+""Ctrl+""ડિલીટ કરો""Enter""Function+""Meta+""Shift+""Spacebar""Sym+""મેનૂ+""શોધો…""ક્વેરી સાફ કરો""શોધ ક્વેરી""શોધો""ક્વેરી સબમિટ કરો""વૉઇસ શોધ""આની સાથે શેર કરો""%sની સાથે શેર કરો""સંકુચિત કરો""શોધો"54dip"होम पेज पर जाएं""ऊपर जाएं""ज़्यादा विकल्प""हो गया""सभी देखें""कोई एप्लिकेशन चुनें""बंद""चालू""Alt+""Ctrl+""delete""enter""Function+""Meta+""Shift+""space""Sym+""Menu+""खोजा जा रहा है…""क्वेरी साफ़ करें""सर्च क्वेरी""सर्च करें""क्वेरी सबमिट करें""आवाज़ सर्च""इसके साथ शेयर करें""%s के साथ शेयर करें""छोटा करें""सर्च""Idi na početnu""Idi gore""Dodatne opcije""Gotovo""Prikaži sve""Odabir aplikacije""ISKLJUČENO""UKLJUČENO""Alt+""Ctrl+""delete""enter""Function+""Meta+""Shift+""razmaknica""Sym+""Menu+""Pretražite…""Izbriši upit""Upit za pretraživanje""Pretraživanje""Pošalji upit""Glasovno pretraživanje""Dijeljenje sa""Dijeli putem aplikacije %s""Sažmi""Pretraživanje""Ugrás a főoldalra""Felfelé mozgatás""További lehetőségek""Kész""Összes megtekintése""Válasszon ki egy alkalmazást""KI""BE""Alt+""Ctrl+""Delete""Enter""Function+""Meta+""Shift+""Szóköz""Sym+""Menu+""Keresés…""Lekérdezés törlése""Keresési lekérdezés""Keresés""Lekérdezés küldése""Hangalapú keresés""Megosztás a következővel:""Megosztás a következő alkalmazással: %s""Összecsukás""Keresés""Ուղղվել տուն""Ուղղվել վերև""Այլ ընտրանքներ""Պատրաստ է""Տեսնել բոլորը""Ընտրել ծրագիր""ԱՆՋԱՏՎԱԾ""ՄԻԱՑՎԱԾ""Alt+""Ctrl+""Delete""Enter""Function+""Meta+""Shift+""բացատ""Sym+""Menu+""Որոնում...""Մաքրել հարցումը""Որոնման հարցում""Որոնել""Ուղարկել հարցումը""Ձայնային որոնում""Կիսվել""Ուղարկել %s-ին""Թաքցնել""Որոնել""Navigasi ke beranda""Navigasi naik""Opsi lain""Selesai""Lihat semua""Pilih aplikasi""NONAKTIF""AKTIF""Alt+""Ctrl+""delete""enter""Function+""Meta+""Shift+""spasi""Sym+""Menu+""Telusuri...""Hapus kueri""Kueri penelusuran""Telusuri""Kirim kueri""Penelusuran suara""Bagikan dengan""Bagikan ke %s""Ciutkan""Telusuri""Fara heim""Fara upp""Fleiri valkostir""Lokið""Sjá allt""Veldu forrit""SLÖKKT""KVEIKT""Alt+""Ctrl+""delete""enter""Aðgerðarlykill+""Meta+""Shift+""bilslá""Sym+""Valmynd+""Leita…""Hreinsa fyrirspurn""Leitarfyrirspurn""Leita""Senda fyrirspurn""Raddleit""Deila með""Deila með %s""Minnka""Leita""Vai alla home page""Vai in alto""Altre opzioni""Fine""Visualizza tutte""Scegli un\'applicazione""OFF""ON""ALT +""CTRL +""CANC""INVIO""FUNZIONE +""META +""MAIUSC +""barra spaziatrice""SYM +""MENU +""Cerca…""Cancella query""Query di ricerca""Cerca""Invia query""Ricerca vocale""Condividi con""Condividi tramite %s""Comprimi""Ricerca""נווט לדף הבית""נווט למעלה""עוד אפשרויות""בוצע""ראה הכל""בחר אפליקציה""כבוי""פועל""Alt+""Ctrl+""delete""Enter""Function+""Meta+""Shift+""מקש רווח""Sym+""תפריט+""חיפוש…""מחק שאילתה""שאילתת חיפוש""חיפוש""שלח שאילתה""חיפוש קולי""שתף עם""שתף עם %s""כווץ""חיפוש""ホームへ移動""上へ移動""その他のオプション""完了""すべて表示""アプリの選択""OFF""ON""Alt+""Ctrl+""Delete""Enter""Function+""Meta+""Shift+""Space""Sym+""Menu+""検索…""検索キーワードを削除""検索キーワード""検索""検索キーワードを送信""音声検索""共有""%sと共有""折りたたむ""検索""მთავარზე ნავიგაცია""ზემოთ ნავიგაცია""მეტი ვარიანტები""დასრულდა""ყველას ნახვა""აპის არჩევა""გამორთულია""ჩართულია""Alt+""Ctrl+""წაშლა""შეყვანა""Function+""Meta+""Shift+""space""Sym+""Menu+""ძიება...""მოთხოვნის გასუფთავება""ძიების მოთხოვნა""ძიება""მოთხოვნის გადაგზავნა""ხმოვანი ძიება""გაზიარება:""გაუზიარეთ %s-ს""აკეცვა""ძიება""Негізгі бетте қозғалу""Жоғары қозғалу""Басқа опциялар""Дайын""Барлығын көру""Қолданбаны таңдау""ӨШІРУЛІ""ҚОСУЛЫ""Alt+""Ctrl+""delete""enter""Function+""Meta+""Shift+""бос орын""Sym+""Mәзір+""Іздеу…""Сұрақты жою""Сұрақты іздеу""Іздеу""Сұрақты жіберу""Дауыс арқылы іздеу""Бөлісу""%s қолданбасымен бөлісу""Тасалау""Іздеу""រកមើលទៅដើម""រកមើលឡើងលើ""ជម្រើសច្រើនទៀត""រួចរាល់""មើលទាំងអស់""ជ្រើសកម្មវិធី""បិទ""បើក""Alt+""Ctrl+""delete""enter""Function+""Meta+""Shift+""space""Sym+""Menu+""ស្វែងរក…""សម្អាតសំណួរ""ស្វែងរកសំណួរ""ស្វែងរក""ដាក់ស្នើសំណួរ""ការស្វែងរកសំឡេង""ចែករំលែកជាមួយ""ចែករំលែកជាមួយ %s""បង្រួម""ស្វែងរក""ಮುಖಪುಟವನ್ನು ನ್ಯಾವಿಗೇಟ್ ಮಾಡಿ""ಮೇಲಕ್ಕೆ ನ್ಯಾವಿಗೇಟ್ ಮಾಡಿ""ಇನ್ನಷ್ಟು ಆಯ್ಕೆಗಳು""ಮುಗಿದಿದೆ""ಎಲ್ಲವನ್ನೂ ನೋಡಿ""ಒಂದು ಅಪ್ಲಿಕೇಶನ್ ಆಯ್ಕೆಮಾಡಿ""ಆಫ್""ಆನ್""Alt+""Ctrl+""delete""enter""Function+""Meta+""Shift+""space""Sym+""Menu+""ಹುಡುಕಿ…""ಪ್ರಶ್ನೆಯನ್ನು ತೆರವುಗೊಳಿಸು""ಪ್ರಶ್ನೆಯನ್ನು ಹುಡುಕಿ""ಹುಡುಕಿ""ಪ್ರಶ್ನೆಯನ್ನು ಸಲ್ಲಿಸು""ಧ್ವನಿ ಹುಡುಕಾಟ""ಇವರೊಂದಿಗೆ ಹಂಚಿಕೊಳ್ಳಿ""%s ನೊಂದಿಗೆ ಹಂಚಿಕೊಳ್ಳಿ""ಸಂಕುಚಿಸು""ಹುಡುಕಿ""홈 탐색""위로 탐색""옵션 더보기""완료""전체 보기""앱 선택""사용 안함""사용""Alt+""Ctrl+""삭제""입력""Function+""Meta+""Shift+""스페이스바""Sym+""Menu+""검색...""검색어 삭제""검색어""검색""검색어 보내기""음성 검색""공유 대상""%s와(과) 공유""접기""검색""Үйгө багыттоо""Жогору""Көбүрөөк мүмкүнчүлүктөр""Даяр""Бардыгын көрүү""Колдонмо тандоо""ӨЧҮК""КҮЙҮК""Alt+""Ctrl+""Delete""Enter""Function+""Meta+""Shift+""боштук""Sym+""Menu+""Издөө…""Талаптарды тазалоо""Издөө талаптары""Издөө""Талап жөнөтүү""Үн аркылуу издөө""Бөлүшүү""%s аркылуу бөлүшүү""Жыйнап коюу""Издөө"48dp12dp14dp440dp60%90%60%90%55%80%"ກັບໄປໜ້າຫຼັກ""ຂຶ້ນເທິງ""ໂຕເລືອກອື່ນ""ແລ້ວໆ""ເບິ່ງທັງຫມົດ""ເລືອກແອັບຯ""ປິດ""ເປີດ""Alt+""Ctrl+""delete""enter""Function+""Meta+""Shift+""space""Sym+""Menu+""ຊອກຫາ""ລຶບຂໍ້ຄວາມຊອກຫາ""ຊອກຫາ""ຊອກຫາ""ສົ່ງການຊອກຫາ""ຊອກຫາດ້ວຍສຽງ""ແບ່ງປັນກັບ""ແບ່ງປັນດ້ວຍ %s""ຫຍໍ້""ຊອກຫາ""Eiti į pagrindinį puslapį""Eiti į viršų""Daugiau parinkčių""Atlikta""Peržiūrėti viską""Pasirinkti programą""IŠJUNGTA""ĮJUNGTI""„Alt“ +""„Ctrl“ +""„Delete“""„Enter“""„Function“ +""„Meta“ +""„Shift“ +""tarpo klavišas""„Sym“ +""„Menu“ +""Ieškoti...""Išvalyti užklausą""Paieškos užklausa""Paieška""Pateikti užklausą""Paieška balsu""Bendrinti naudojant""Bendrinti naudojant programą „%s“""Sutraukti""Paieška""Pārvietoties uz sākuma ekrānu""Pārvietoties augšup""Vairāk opciju""Gatavs""Skatīt visu""Izvēlieties lietotni""IZSLĒGTS""IESLĒGTS""Alternēšanas taustiņš +""Vadīšanas taustiņš +""dzēšanas taustiņš""ievadīšanas taustiņš""Funkcijas taustiņš +""Meta taustiņš +""Pārslēgšanas taustiņš +""atstarpes taustiņš""Simbolu taustiņš +""Poga Izvēlne +""Meklējiet…""Notīrīt vaicājumu""Meklēšanas vaicājums""Meklēt""Iesniegt vaicājumu""Meklēšana ar balsi""Kopīgot ar:""Kopīgot ar lietojumprogrammu %s""Sakļaut""Meklēt""Движи се кон дома""Движи се нагоре""Повеќе опции""Готово""Види ги сите""Избери апликација""ИСКЛУЧЕНО""ВКЛУЧЕНО""копче Alt+""копче Ctrl+""избриши""копче enter""копче Function+""копче Meta+""копче Shift+""вселена""копче Sym+""Мени+""Пребарување…""Исчисти барање""Пребарај барање""Пребарај""Поднеси барање""Гласовно пребарување""Сподели со""Сподели со %s""Собери""Пребарај""ഹോമിലേക്ക് നാവിഗേറ്റുചെയ്യുക""മുകളിലേക്ക് നാവിഗേറ്റുചെയ്യുക""കൂടുതൽ ഓപ്ഷനുകള്""പൂർത്തിയാക്കി""എല്ലാം കാണുക""ഒരു അപ്ലിക്കേഷൻ തിരഞ്ഞെടുക്കുക""ഓഫ്""ഓൺ""Alt+""Ctrl+""ഇല്ലാതാക്കുക""enter""ഫംഗ്ഷന്+""മെറ്റ+""Shift+""സ്പെയ്സ്""Sym+""മെനു+""തിരയുക…""അന്വേഷണം മായ്ക്കുക""തിരയൽ അന്വേഷണം""തിരയൽ""അന്വേഷണം സമർപ്പിക്കുക""ശബ്ദതിരയൽ""ഇവരുമായി പങ്കിടുക""%s-മായി പങ്കിടുക""ചുരുക്കുക""തിരയുക""Нүүр хуудас руу шилжих""Дээш шилжих""Нэмэлт сонголтууд""Дууссан""Бүгдийг харах""Апп сонгох""ИДЭВХГҮЙ""ИДЭВХТЭЙ""Alt+""Ctrl+""устгах""оруулах""Функц+""Мета+""Shift+""зай""Sym+""Цэс+""Хайх...""Асуулгыг цэвэрлэх""Хайх асуулга""Хайх""Асуулгыг илгээх""Дуут хайлт""Хуваалцах""%s-тай хуваалцах""Хумих""Хайлт""होमवर नेव्हिगेट करा""वर नेव्हिगेट करा""अधिक पर्याय""पूर्ण झाले""सर्व पहा""एक अॅप निवडा""बंद""चालू""Alt+""Ctrl+""हटवा""एंटर करा""Function+""Meta+""Shift+""spacebar""Sym+""मेनू+""शोधा…""क्वेरी स्पष्ट करा""शोध क्वेरी""शोध""क्वेरी सबमिट करा""व्हॉइस शोध""यांच्यासह शेअर करा""%s सह शेअर करा""संक्षिप्त करा""शोधा""Navigasi skrin utama""Navigasi ke atas""Lagi pilihan""Selesai""Lihat semua""Pilih apl""MATI""HIDUP""Alt+""Ctrl+""padam""enter""Fungsi+""Meta+""Shift+""ruang""Sym+""Menu+""Cari…""Kosongkan pertanyaan""Pertanyaan carian""Cari""Serah pertanyaan""Carian suara""Kongsi dengan""Kongsi dengan %s""Runtuhkan""Cari""မူလနေရာကို သွားရန်""အပေါ်သို့သွားရန်""ပိုမိုရွေးချယ်စရာများ""ပြီးဆုံးပါပြီ""အားလုံးကို ကြည့်ရန်""အက်ပ်တစ်ခုခုကို ရွေးချယ်ပါ""ပိတ်""ဖွင့်""Alt+""Ctrl+""delete""enter""Function+""Meta+""Shift+""space""Sym+""Menu+""ရှာဖွေပါ...""ရှာစရာ အချက်အလက်များ ဖယ်ရှားရန်""ရှာစရာ အချက်အလက်နေရာ""ရှာဖွေရန်""ရှာဖွေစရာ အချက်အလက်ကို ပေးပို့ရန်""အသံဖြင့် ရှာဖွေခြင်း""မျှဝေဖို့ ရွေးပါ""%s ဖြင့် မျှဝေရန်""ခေါက်ရန်""ရှာဖွေပါ""Gå til startsiden""Gå opp""Flere alternativer""Ferdig""Se alle""Velg en app""AV""PÅ""Alt+""Ctrl+""delete""enter""Funksjon+""Meta+""Shift+""mellomrom""Sym+""Meny+""Søk …""Slett søket""Søkeord""Søk""Utfør søket""Talesøk""Del med""Del med %s""Skjul""Søk""गृह खोज्नुहोस्""माथि खोज्नुहोस्""थप विकल्पहरू""सम्पन्न भयो""सबै हेर्नुहोस्""एउटा अनुप्रयोग छान्नुहोस्""निष्क्रिय पार्नुहोस्""सक्रिय गर्नुहोस्""Alt+""Ctrl+""delete""enter""Function+""Meta+""Shift+""space""Sym+""Menu+""खोज्नुहोस्...""प्रश्न हटाउनुहोस्""जिज्ञासाको खोज गर्नुहोस्""खोज्नुहोस्""जिज्ञासा पेस गर्नुहोस्""भ्वाइस खोजी""साझेदारी गर्नुहोस्...""%s सँग आदान प्रदान गर्नुहोस्""संक्षिप्त पार्नुहोस्""खोज्नुहोस्""Navigeren naar startpositie""Omhoog navigeren""Meer opties""Gereed""Alles weergeven""Een app selecteren""UIT""AAN""Alt +""Ctrl +""verwijderen""enter""Functie +""Meta +""Shift +""spatie""Sym +""Menu +""Zoeken…""Zoekopdracht wissen""Zoekopdracht""Zoeken""Zoekopdracht verzenden""Gesproken zoekopdracht""Delen met""Delen met %s""Samenvouwen""Zoeken""ହୋମ୍ ପେଜ୍କୁ ନେଭିଗେଟ୍ କରନ୍ତୁ""ଉପରକୁ ନେଭିଗେଟ୍ କରନ୍ତୁ""ଅଧିକ ବିକଳ୍ପ""ହୋଇଗଲା""ସବୁ ଦେଖନ୍ତୁ""ଗୋଟିଏ ଆପ୍ ବାଛନ୍ତୁ""ଅଫ୍""ଅନ୍""Alt+""Ctrl+""ଡିଲିଟ୍""ଏଣ୍ଟର୍""Function+""Meta+""Shift+""ସ୍ପେସ୍""Sym+""ମେନୁ""ସର୍ଚ୍ଚ…""କ୍ୱେରୀ ଖାଲି କରନ୍ତୁ""ସର୍ଚ୍ଚ କ୍ୱେରୀ""ସର୍ଚ୍ଚ କରନ୍ତୁ""କ୍ୱେରୀ ଦାଖଲ କରନ୍ତୁ""ଭଏସ୍ ସର୍ଚ୍ଚ""ଏହାଙ୍କ ସହ ଶେୟାର୍ କରନ୍ତୁ""%s ସହ ଶେୟାର୍ କରନ୍ତୁ""ଛୋଟ କରନ୍ତୁ""ସର୍ଚ୍ଚ କରନ୍ତୁ""ਹੋਮ \'ਤੇ ਜਾਓ""ਉੱਪਰ ਜਾਓ""ਹੋਰ ਚੋਣਾਂ""ਹੋ ਗਿਆ""ਸਭ ਦੇਖੋ""ਇੱਕ ਐਪ ਚੁਣੋ""ਬੰਦ""ਤੇ""Alt+""Ctrl+""delete""enter""Function+""Meta+""Shift+""space""Sym+""Menu+""ਖੋਜ…""ਸਵਾਲ ਹਟਾਓ""ਖੋਜ ਪੁੱਛਗਿੱਛ""ਖੋਜੋ""ਸਵਾਲ ਪ੍ਰਸਤੁਤ ਕਰੋ""ਵੌਇਸ ਖੋਜ""ਇਸ ਨਾਲ ਸਾਂਝਾ ਕਰੋ""%s ਨਾਲ ਸਾਂਝਾ ਕਰੋ""ਨਸ਼ਟ ਕਰੋ""ਖੋਜੋ""Przejdź do strony głównej""Przejdź wyżej""Więcej opcji""Gotowe""Zobacz wszystkie""Wybierz aplikację""WYŁ.""WŁ.""Alt+""Ctrl+""Delete""Enter""Funkcyjny+""Meta+""Shift+""spacja""Sym+""Menu+""Szukaj…""Wyczyść zapytanie""Wyszukiwane hasło""Szukaj""Wyślij zapytanie""Wyszukiwanie głosowe""Udostępnij dla""Udostępnij przez: %s""Zwiń""Szukaj"false"Navegar para a página inicial""Navegar para cima""Mais opções""Concluído""Ver tudo""Selecione um app""DESATIVAR""ATIVAR""Alt+""Ctrl+""delete""enter""Function+""Meta+""Shift+""espaço""Sym+""Menu+""Pesquisar...""Limpar consulta""Consulta de pesquisa""Pesquisar""Enviar consulta""Pesquisa por voz""Compartilhar com""Compartilhar com %s""Recolher""Pesquisar""Navegar para a página inicial""Navegar para cima""Mais opções""Concluído""Ver tudo""Selecione um app""DESATIVAR""ATIVAR""Alt+""Ctrl+""delete""enter""Function+""Meta+""Shift+""espaço""Sym+""Menu+""Pesquisar...""Limpar consulta""Consulta de pesquisa""Pesquisar""Enviar consulta""Pesquisa por voz""Compartilhar com""Compartilhar com %s""Recolher""Pesquisar""Navegar para a página inicial""Navegar para cima""Mais opções""Concluído""Ver tudo""Escolher uma aplicação""DESATIVADO""ATIVADO""Alt +""Ctrl +""eliminar""enter""Função +""Meta +""Shift +""espaço""Sym +""Menu +""Pesquisar...""Limpar consulta""Consulta de pesquisa""Pesquisar""Enviar consulta""Pesquisa por voz""Partilhar com""Partilhar com a aplicação %s""Reduzir""Pesquisar""Navigați la ecranul de pornire""Navigați în sus""Mai multe opțiuni""Terminat""Afișați-le pe toate""Alegeți o aplicație""DEZACTIVAȚI""ACTIVAT""Alt+""Ctrl+""delete""enter""Funcție+""Meta+""Shift+""spațiu""Sym+""Meniu+""Căutați…""Ștergeți interogarea""Interogare de căutare""Căutați""Trimiteți interogarea""Căutare vocală""Trimiteți la""Trimiteți folosind %s""Restrângeți""Căutați""Перейти на главный экран""Перейти вверх""Другие параметры""Готово""Показать все""Выбрать приложение""ОТКЛ.""ВКЛ.""Alt +""Ctrl +""Delete""Ввод""Fn +""Meta +""Shift +""Пробел""Sym +""Меню +""Поиск""Удалить запрос""Поисковый запрос""Поиск""Отправить запрос""Голосовой поиск""Открыть доступ""Открыть доступ приложению \"%s\"""Свернуть""Поиск""ගෙදරට සංචාලනය කරන්න""ඉහලට සංචාලනය කරන්න""තවත් විකල්ප""අවසාන වූ""සියල්ල බලන්න""යෙදුමක් තෝරන්න""ක්රියාවිරහිතයි""ක්රියාත්මකයි""Alt+""Ctrl+""මකන්න""enter""Function+""Meta+""Shift+""space""Sym+""Menu+""සොයන්න...""විමසුම හිස් කරන්න""සෙවුම් විමසුම""සෙවීම""විමසුම යොමු කරන්න""හඬ සෙවීම""සමඟ බෙදාගන්න""%s සමඟ බෙදා ගන්න""හකුළන්න""සොයන්න""Prejsť na plochu""Prejsť hore""Ďalšie možnosti""Hotovo""Zobraziť všetko""Zvoľte aplikáciu""VYPNUTÉ""ZAPNUTÉ""Alt+""Ctrl+""odstrániť""enter""Function+""Meta+""Shift+""medzerník""Sym+""Menu+""Vyhľadať…""Vymazať dopyt""Vyhľadávací dopyt""Hľadať""Odoslať dopyt""Hlasové vyhľadávanie""Zdieľať pomocou""Zdieľať s aplikáciou %s""Zbaliť""Vyhľadávanie""Krmarjenje domov""Krmarjenje navzgor""Več možnosti""Končano""Pokaži vse""Izbira aplikacije""IZKLOPLJENO""VKLOPLJENO""Alt +""Ctrl +""Delete""Enter""Fn +""Meta +""Shift +""preslednica""Sym +""Meni +""Iskanje …""Izbris poizvedbe""Iskalna poizvedba""Iskanje""Pošiljanje poizvedbe""Glasovno iskanje""Deljenje z""Deljenje z drugimi prek aplikacije %s""Strni""Iskanje""Orientohu për në shtëpi""Ngjitu lart""Opsione të tjera""U krye!""Shikoji të gjitha""Zgjidh një aplikacion""JOAKTIV""AKTIV""Alt+""Ctrl+""delete""enter""Funksioni+""Meta+""Shift+""hapësirë""Sym+""Menyja+""Kërko...""Pastro pyetjen""Kërko pyetjen""Kërko""Dërgo pyetjen""Kërkim me zë""Shpërnda publikisht me""Ndaje me %s""Shpalos""Kërko""Одлазак на Почетну""Кретање нагоре""Још опција""Готово""Прикажи све""Избор апликације""ИСКЉУЧИ""УКЉУЧИ""Alt+""Ctrl+""delete""enter""Function+""Meta+""Shift+""тастер за размак""Sym+""Menu+""Претражите...""Брисање упита""Упит за претрагу""Претрага""Слање упита""Гласовна претрага""Дели са""Дељење са апликацијом %s""Скупи""Претражи""Visa startsidan""Navigera uppåt""Fler alternativ""Klart""Visa alla""Välj en app""AV""PÅ""Alt + ""Ctrl + ""delete""retur""Funktion + ""Meta + ""Skift + ""blanksteg""Symbol + ""Meny + ""Sök …""Ta bort frågan""Sökfråga""Sök""Skicka fråga""Röstsökning""Dela med""Dela med %s""Komprimera""Sök""Nenda mwanzo""Nenda juu""Chaguo zaidi""Nimemaliza""Angalia zote""Chagua programu""IMEZIMWA""IMEWASHWA""Alt+""Ctrl+""futa""enter""Function+""Meta+""Shift+""nafasi""Sym+""Menyu+""Tafuta…""Futa hoja""Hoja ya utafutaji""Tafuta""Wasilisha hoja""Tafuta kwa kutamka""Shiriki na:""Shiriki ukitumia %s""Kunja""Tafuta"24dp80dp64dp8dp8dp580dp16dp20dp"முகப்பிற்கு வழிசெலுத்து""மேலே செல்""மேலும் விருப்பங்கள்""முடிந்தது""எல்லாம் காட்டு""பயன்பாட்டைத் தேர்வுசெய்க""ஆஃப்""ஆன்""ஆல்ட் மற்றும்""கண்ட்ரோல் மற்றும்""டெலிட்""எண்டர்""ஃபங்ஷன் மற்றும்""மெட்டா மற்றும்""ஷிஃப்ட் மற்றும்""ஸ்பேஸ்""சிம்பல் மற்றும்""மெனு மற்றும்""தேடு...""வினவலை அழி""தேடல் வினவல்""தேடு""வினவலைச் சமர்ப்பி""குரல் தேடல்""இதனுடன் பகிர்""%s மூலம் பகிர்""சுருக்கு""தேடு""హోమ్కు నావిగేట్ చేయండి""పైకి నావిగేట్ చేయండి""మరిన్ని ఎంపికలు""పూర్తయింది""అన్నీ చూడండి""అనువర్తనాన్ని ఎంచుకోండి""ఆఫ్ చేయి""ఆన్ చేయి""Alt+""Ctrl+""delete""enter""Function+""Meta+""Shift+""స్పేస్""Sym+""Menu+""వెతుకు...""ప్రశ్నను క్లియర్ చేయి""ప్రశ్న శోధించండి""వెతుకు""ప్రశ్నని సమర్పించు""వాయిస్ శోధన""వీరితో భాగస్వామ్యం చేయి""%sతో భాగస్వామ్యం చేయండి""కుదించండి""వెతుకు""นำทางไปหน้าแรก""นำทางขึ้น""ตัวเลือกอื่น""เสร็จสิ้น""ดูทั้งหมด""เลือกแอป""ปิด""เปิด""Alt+""Ctrl+""Delete""Enter""Function+""Meta+""Shift+""Space""Sym+""เมนู+""ค้นหา…""ล้างข้อความค้นหา""ข้อความค้นหา""ค้นหา""ส่งข้อความค้นหา""ค้นหาด้วยเสียง""แชร์กับ""แชร์ทาง %s""ยุบ""ค้นหา""Mag-navigate patungo sa home""Mag-navigate pataas""Higit pang mga opsyon""Tapos na""Tingnan lahat""Pumili ng isang app""I-OFF""I-ON""Alt+""Ctrl+""delete""enter""Function+""Meta+""Shift+""space""Sym+""Menu+""Maghanap…""I-clear ang query""Query sa paghahanap""Maghanap""Isumite ang query""Paghahanap gamit ang boses""Ibahagi sa/kay""Ibahagi gamit ang %s""I-collapse""Maghanap""Ana ekrana git""Yukarı git""Diğer seçenekler""Bitti""Tümünü göster""Bir uygulama seçin""KAPAT""AÇ""Alt+""Ctrl+""sil""enter""İşlev+""Meta+""Üst Karakter+""boşluk""Sym+""Menü+""Ara…""Sorguyu temizle""Arama sorgusu""Ara""Sorguyu gönder""Sesli arama""Şununla paylaş""%s ile paylaş""Daralt""Ara""Перейти на головний""Перейти вгору""Інші опції""Готово""Переглянути всі""Вибрати програму""ВИМК.""УВІМК.""Alt+""Ctrl+""delete""enter""Function+""Meta+""Shift+""пробіл""Sym+""Menu+""Пошук…""Очистити запит""Пошуковий запит""Пошук""Надіслати запит""Голосовий пошук""Надіслати через""Поділитися через додаток %s""Згорнути""Пошук""ہوم پر نیویگیٹ کریں""اوپر نیویگیٹ کریں""مزید اختیارات""ہو گیا""سبھی دیکھیں""ایک ایپ منتخب کریں""آف""آن""Alt+""Ctrl+""delete""enter""Function+""Meta+""Shift+""space""Sym+""Menu+""تلاش کریں…""استفسار صاف کریں""استفسار تلاش کریں""تلاش کریں""استفسار جمع کرائیں""صوتی تلاش""اشتراک کریں مع""%s کے ساتھ اشتراک کریں""سکیڑیں""تلاش""Boshiga o‘tish""Yuqoriga o‘tish""Boshqa parametrlar""Tayyor""Hammasi""Dastur tanlang""O‘CHIQ""YONIQ""Alt+""Ctrl+""Delete""Enter""Fn+""Meta+""Shift+""Probel""Sym+""Menyu+""Qidirish…""So‘rovni tozalash""So‘rovni izlash""Qidirish""So‘rov yaratish""Ovozli qidiruv""Ruxsat berish""%s orqali ulashish""Yig‘ish""Qidirish"0px"Điều hướng về trang chủ""Điều hướng lên trên""Tùy chọn khác""Xong""Xem tất cả""Chọn một ứng dụng""TẮT""BẬT""Alt+""Ctrl+""delete""enter""Function+""Meta+""Shift+""phím cách""Sym+""Menu+""Tìm kiếm…""Xóa truy vấn""Tìm kiếm truy vấn""Tìm kiếm""Gửi truy vấn""Tìm kiếm bằng giọng nói""Chia sẻ với""Chia sẻ với %s""Thu gọn""Tìm kiếm"60%90%50%70%45%72%"转到主屏幕""转到上一层级""更多选项""完成""查看全部""选择应用""关闭""开启""Alt+""Ctrl+""Delete 键""Enter 键""Fn+""Meta+""Shift+""空格键""Sym+""Menu+""搜索…""清除查询""搜索查询""搜索""提交查询""语音搜索""分享方式""使用%s分享""收起""搜索""瀏覽主頁""向上瀏覽""更多選項""完成""顯示全部""選擇應用程式""關閉""開啟""Alt +""Ctrl +""刪除""Enter 鍵""Fn +""Meta +""Shift +""空白鍵""Sym +""Menu +""搜尋…""清除查詢""搜尋查詢""搜尋""提交查詢""語音搜尋""分享對象""使用「%s」分享""收合""搜尋""瀏覽首頁""向上瀏覽""更多選項""完成""查看全部""選擇應用程式""關閉""開啟""Alt +""Ctrl +""Delete 鍵""Enter 鍵""Fn +""Meta +""Shift +""空格鍵""Sym +""Menu +""搜尋…""清除查詢""搜尋查詢""搜尋""提交查詢""語音搜尋""選擇分享對象""與「%s」分享""收合""搜尋""Zulazulela ekhaya""Zulazulela phezulu""Izinketho eziningi""Kwenziwe""Buka konke""Khetha uhlelo lokusebenza""VALIWE""VULIWE""Alt+""Ctrl+""susa""enter""Function+""Meta+""Shift+""space""Sym+""Imenyu+""Iyasesha...""Sula inkinga""Umbuzo wosesho""Sesha""Hambisa umbuzo""Ukusesha ngezwi""Yabelana no-""Yabelana ne-%s""Goqa""Sesha"
+ -%s
+ --%s
+ --%s
+ --%s
+
+ Messaging
+ Email
+ #335b5b5b33sp26sp20sp17sp14spset private modecount how many notes are theredelete private modePlease input PassWordopen the albumtake photostart drawset gestrueswitch to default gestrueNotesNotes 2x2Notes 4x4No associated note found, click to create associated note.Privacy mode,can not see note content...Add noteDelete reminder successfullySet reminderExpiredyyyyMMddMMMd kk:mmGot itTake a lookCallSend emailBrowse webOpen map/MIUI/notes/notes_%s.txt(%d)New FolderExport textSyncCancel syncingSettingsSearchDeleteMove to folder%d selectedNothing selected, the operation is invalidSelect allDeselect allFont sizeSmallMediumLargeSuperEnter check listLeave check listView folderDelete folderChange folder nameThe folder %1$s exist, please renameShareSend to homeRemind meDelete reminderSelect folderParent folderNote added to homeConfirm to delete folder and its notes?Delete selected notesConfirm to delete the selected %d notes?Confirm to delete this note?Have moved selected %1$d notes to %2$s folderSD card busy, not available nowExport failed, please check SD cardThe note is not existSorry, can not set clock on empty noteSorry, can not send and empty note to homeExport successfulExport failExport text file (%1$s) to SD (%2$s) directorySyncing notes...Sync is successfulSync is failedSync is canceledSync is successful with account %1$sSync failed, please check network and account settingsSync failed, internal error occursSync is canceledLogging into %1$s...Getting remote note list...Synchronize local notes with Google Task...SettingsSync accountSync notes with google taskLast sync time %1$syyyy-MM-dd hh:mm:ssAdd accountChange sync accountRemove sync accountCancelSync immediatelyCancel syncingCurrent account %1$sAll sync related information will be deleted, which may result in duplicated items sometimeSync notesPlease select a google account. Local notes will be synced with google task.Cannot change the account because sync is in progress%1$s has been set as the sync accountNew note background color randomDeleteCall notesInput nameSearching NotesSearch notesText in your notesNotessetcancel
+ %1$s result for \"%2$s\"
+
+ %1$s results for \"%2$s\"
+
+ 短信
+ 邮件
+ 设置为隐私便签显示目前便签数量撤销隐私便签输入隐私密码插入图片打开相机手绘采用自定义手势采用默认手势便签便签2x2便签4x4没有关联内容,点击新建便签。访客模式下,便签内容不可见...新建便签成功删除提醒创建提醒已过期yyyyMMddMM月dd日 kk:mm知道了查看呼叫电话发送邮件浏览网页打开地图新建文件夹导出文本同步取消同步设置搜索删除移动到文件夹选中了 %d 项没有选中项,操作无效全选取消全选文字大小小正常大超大进入清单模式退出清单模式查看文件夹刪除文件夹修改文件夹名称文件夹 %1$s 已存在,请重新命名分享发送到桌面提醒我删除提醒选择文件夹上一级文件夹已添加到桌面删除确认要删除所选的 %d 条便签吗?确认要删除该条便签吗?确认删除文件夹及所包含的便签吗?已将所选 %1$d 条便签移到 %2$s 文件夹SD卡被占用,不能操作导出文本时发生错误,请检查SD卡要查看的便签不存在不能为空便签设置闹钟提醒不能将空便签发送到桌面导出成功导出失败已将文本文件(%1$s)输出至SD卡(%2$s)目录同步便签...同步成功同步失败同步已取消与%1$s同步成功同步失败,请检查网络和帐号设置同步失败,发生内部错误同步已取消登录%1$s...正在获取服务器便签列表...正在同步本地便签...设置同步账号与google task同步便签记录上次同步于 %1$s添加账号更换账号删除账号取消立即同步取消同步当前帐号 %1$s如更换同步帐号,过去的帐号同步信息将被清空,再次切换的同时可能会造成数据重复同步便签请选择google帐号,便签将与该帐号的google task内容同步。正在同步中,不能修改同步帐号同步帐号已设置为%1$s新建便签背景颜色随机删除通话便签请输入名称正在搜索便签搜索便签便签中的文字便签设置取消
+ %1$s 条符合“%2$s”的搜索结果
+
+ 短信
+ 郵件
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
\ No newline at end of file
diff --git a/src/src/app/build/intermediates/incremental/mergeDebugShaders/merger.xml b/src/src/app/build/intermediates/incremental/mergeDebugShaders/merger.xml
new file mode 100644
index 0000000..f7362a8
--- /dev/null
+++ b/src/src/app/build/intermediates/incremental/mergeDebugShaders/merger.xml
@@ -0,0 +1,2 @@
+
+
\ No newline at end of file
diff --git a/src/src/app/build/intermediates/incremental/packageDebug/tmp/debug/dex-renamer-state.txt b/src/src/app/build/intermediates/incremental/packageDebug/tmp/debug/dex-renamer-state.txt
new file mode 100644
index 0000000..1262fa1
--- /dev/null
+++ b/src/src/app/build/intermediates/incremental/packageDebug/tmp/debug/dex-renamer-state.txt
@@ -0,0 +1,4 @@
+#Thu Feb 25 07:58:07 CST 2021
+base.0=E\:\\Note\\src\\app\\build\\intermediates\\dex\\debug\\mergeDexDebug\\classes.dex
+path.0=classes.dex
+renamed.0=classes.dex
diff --git a/src/src/app/build/intermediates/incremental/packageDebug/tmp/debug/zip-cache/androidResources b/src/src/app/build/intermediates/incremental/packageDebug/tmp/debug/zip-cache/androidResources
new file mode 100644
index 0000000..2db7e25
Binary files /dev/null and b/src/src/app/build/intermediates/incremental/packageDebug/tmp/debug/zip-cache/androidResources differ
diff --git a/src/src/app/build/intermediates/incremental/packageDebug/tmp/debug/zip-cache/javaResources0 b/src/src/app/build/intermediates/incremental/packageDebug/tmp/debug/zip-cache/javaResources0
new file mode 100644
index 0000000..60772cc
Binary files /dev/null and b/src/src/app/build/intermediates/incremental/packageDebug/tmp/debug/zip-cache/javaResources0 differ
diff --git a/src/src/app/build/intermediates/instant_app_manifest/debug/AndroidManifest.xml b/src/src/app/build/intermediates/instant_app_manifest/debug/AndroidManifest.xml
new file mode 100644
index 0000000..aa3faa6
--- /dev/null
+++ b/src/src/app/build/intermediates/instant_app_manifest/debug/AndroidManifest.xml
@@ -0,0 +1,170 @@
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
\ No newline at end of file
diff --git a/src/src/app/build/intermediates/instant_app_manifest/debug/output.json b/src/src/app/build/intermediates/instant_app_manifest/debug/output.json
new file mode 100644
index 0000000..b774efa
--- /dev/null
+++ b/src/src/app/build/intermediates/instant_app_manifest/debug/output.json
@@ -0,0 +1,28 @@
+{
+ "version": 1,
+ "applicationId": "net.micode.notes",
+ "variantType": "BASE_APK",
+ "elements": [
+ {
+ "outputType": {
+ "type": "INSTANT_APP_MANIFEST"
+ },
+ "apkData": {
+ "type": "MAIN",
+ "splits": [],
+ "versionCode": 1,
+ "versionName": "0.1",
+ "outputFile": "app-debug.apk",
+ "fullName": "debug",
+ "baseName": "debug",
+ "dirName": ""
+ },
+ "path": "AndroidManifest.xml",
+ "properties": {
+ "packageId": "net.micode.notes",
+ "split": "",
+ "minSdkVersion": "14"
+ }
+ }
+ ]
+}
\ No newline at end of file
diff --git a/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/BuildConfig.class b/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/BuildConfig.class
new file mode 100644
index 0000000..d9846f9
Binary files /dev/null and b/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/BuildConfig.class differ
diff --git a/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/data/Contact.class b/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/data/Contact.class
new file mode 100644
index 0000000..7f4f3ef
Binary files /dev/null and b/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/data/Contact.class differ
diff --git a/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/data/Notes$CallNote.class b/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/data/Notes$CallNote.class
new file mode 100644
index 0000000..64f2fde
Binary files /dev/null and b/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/data/Notes$CallNote.class differ
diff --git a/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/data/Notes$DataColumns.class b/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/data/Notes$DataColumns.class
new file mode 100644
index 0000000..a4e6edc
Binary files /dev/null and b/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/data/Notes$DataColumns.class differ
diff --git a/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/data/Notes$DataConstants.class b/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/data/Notes$DataConstants.class
new file mode 100644
index 0000000..f1092fc
Binary files /dev/null and b/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/data/Notes$DataConstants.class differ
diff --git a/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/data/Notes$NoteColumns.class b/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/data/Notes$NoteColumns.class
new file mode 100644
index 0000000..2a35549
Binary files /dev/null and b/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/data/Notes$NoteColumns.class differ
diff --git a/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/data/Notes$TextNote.class b/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/data/Notes$TextNote.class
new file mode 100644
index 0000000..330ce77
Binary files /dev/null and b/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/data/Notes$TextNote.class differ
diff --git a/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/data/Notes.class b/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/data/Notes.class
new file mode 100644
index 0000000..3bfbee8
Binary files /dev/null and b/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/data/Notes.class differ
diff --git a/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/data/NotesDatabaseHelper$TABLE.class b/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/data/NotesDatabaseHelper$TABLE.class
new file mode 100644
index 0000000..4d07390
Binary files /dev/null and b/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/data/NotesDatabaseHelper$TABLE.class differ
diff --git a/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/data/NotesDatabaseHelper.class b/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/data/NotesDatabaseHelper.class
new file mode 100644
index 0000000..fb06a11
Binary files /dev/null and b/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/data/NotesDatabaseHelper.class differ
diff --git a/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/data/NotesProvider.class b/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/data/NotesProvider.class
new file mode 100644
index 0000000..692f734
Binary files /dev/null and b/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/data/NotesProvider.class differ
diff --git a/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/gtask/data/MetaData.class b/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/gtask/data/MetaData.class
new file mode 100644
index 0000000..2fbe949
Binary files /dev/null and b/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/gtask/data/MetaData.class differ
diff --git a/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/gtask/data/Node.class b/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/gtask/data/Node.class
new file mode 100644
index 0000000..c2f45a7
Binary files /dev/null and b/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/gtask/data/Node.class differ
diff --git a/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/gtask/data/SqlData.class b/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/gtask/data/SqlData.class
new file mode 100644
index 0000000..447a7c6
Binary files /dev/null and b/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/gtask/data/SqlData.class differ
diff --git a/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/gtask/data/SqlNote.class b/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/gtask/data/SqlNote.class
new file mode 100644
index 0000000..7522f74
Binary files /dev/null and b/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/gtask/data/SqlNote.class differ
diff --git a/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/gtask/data/Task.class b/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/gtask/data/Task.class
new file mode 100644
index 0000000..5033740
Binary files /dev/null and b/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/gtask/data/Task.class differ
diff --git a/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/gtask/data/TaskList.class b/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/gtask/data/TaskList.class
new file mode 100644
index 0000000..fd6b98b
Binary files /dev/null and b/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/gtask/data/TaskList.class differ
diff --git a/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/gtask/exception/ActionFailureException.class b/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/gtask/exception/ActionFailureException.class
new file mode 100644
index 0000000..6a11981
Binary files /dev/null and b/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/gtask/exception/ActionFailureException.class differ
diff --git a/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/gtask/exception/NetworkFailureException.class b/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/gtask/exception/NetworkFailureException.class
new file mode 100644
index 0000000..a7ffbfa
Binary files /dev/null and b/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/gtask/exception/NetworkFailureException.class differ
diff --git a/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/gtask/remote/GTaskASyncTask$1.class b/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/gtask/remote/GTaskASyncTask$1.class
new file mode 100644
index 0000000..f4130b8
Binary files /dev/null and b/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/gtask/remote/GTaskASyncTask$1.class differ
diff --git a/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/gtask/remote/GTaskASyncTask$OnCompleteListener.class b/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/gtask/remote/GTaskASyncTask$OnCompleteListener.class
new file mode 100644
index 0000000..c671684
Binary files /dev/null and b/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/gtask/remote/GTaskASyncTask$OnCompleteListener.class differ
diff --git a/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/gtask/remote/GTaskASyncTask.class b/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/gtask/remote/GTaskASyncTask.class
new file mode 100644
index 0000000..8d2b510
Binary files /dev/null and b/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/gtask/remote/GTaskASyncTask.class differ
diff --git a/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/gtask/remote/GTaskClient.class b/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/gtask/remote/GTaskClient.class
new file mode 100644
index 0000000..8e7b144
Binary files /dev/null and b/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/gtask/remote/GTaskClient.class differ
diff --git a/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/gtask/remote/GTaskManager.class b/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/gtask/remote/GTaskManager.class
new file mode 100644
index 0000000..0e02cf2
Binary files /dev/null and b/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/gtask/remote/GTaskManager.class differ
diff --git a/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/gtask/remote/GTaskSyncService$1.class b/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/gtask/remote/GTaskSyncService$1.class
new file mode 100644
index 0000000..e122d0a
Binary files /dev/null and b/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/gtask/remote/GTaskSyncService$1.class differ
diff --git a/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/gtask/remote/GTaskSyncService.class b/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/gtask/remote/GTaskSyncService.class
new file mode 100644
index 0000000..636f8ed
Binary files /dev/null and b/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/gtask/remote/GTaskSyncService.class differ
diff --git a/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/model/Note$NoteData.class b/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/model/Note$NoteData.class
new file mode 100644
index 0000000..dd25511
Binary files /dev/null and b/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/model/Note$NoteData.class differ
diff --git a/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/model/Note.class b/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/model/Note.class
new file mode 100644
index 0000000..b91202f
Binary files /dev/null and b/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/model/Note.class differ
diff --git a/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/model/WorkingNote$NoteSettingChangedListener.class b/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/model/WorkingNote$NoteSettingChangedListener.class
new file mode 100644
index 0000000..add97e1
Binary files /dev/null and b/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/model/WorkingNote$NoteSettingChangedListener.class differ
diff --git a/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/model/WorkingNote.class b/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/model/WorkingNote.class
new file mode 100644
index 0000000..f7b2393
Binary files /dev/null and b/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/model/WorkingNote.class differ
diff --git a/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/tool/BackupUtils$TextExport.class b/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/tool/BackupUtils$TextExport.class
new file mode 100644
index 0000000..895a584
Binary files /dev/null and b/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/tool/BackupUtils$TextExport.class differ
diff --git a/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/tool/BackupUtils.class b/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/tool/BackupUtils.class
new file mode 100644
index 0000000..9a26c00
Binary files /dev/null and b/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/tool/BackupUtils.class differ
diff --git a/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/tool/DataUtils.class b/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/tool/DataUtils.class
new file mode 100644
index 0000000..7441e70
Binary files /dev/null and b/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/tool/DataUtils.class differ
diff --git a/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/tool/GTaskStringUtils.class b/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/tool/GTaskStringUtils.class
new file mode 100644
index 0000000..0030332
Binary files /dev/null and b/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/tool/GTaskStringUtils.class differ
diff --git a/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/tool/ImageUtils.class b/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/tool/ImageUtils.class
new file mode 100644
index 0000000..0ff8dfa
Binary files /dev/null and b/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/tool/ImageUtils.class differ
diff --git a/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/tool/ResourceParser$NoteBgResources.class b/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/tool/ResourceParser$NoteBgResources.class
new file mode 100644
index 0000000..bb4166f
Binary files /dev/null and b/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/tool/ResourceParser$NoteBgResources.class differ
diff --git a/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/tool/ResourceParser$NoteItemBgResources.class b/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/tool/ResourceParser$NoteItemBgResources.class
new file mode 100644
index 0000000..dc06a48
Binary files /dev/null and b/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/tool/ResourceParser$NoteItemBgResources.class differ
diff --git a/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/tool/ResourceParser$TextAppearanceResources.class b/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/tool/ResourceParser$TextAppearanceResources.class
new file mode 100644
index 0000000..ece4d7e
Binary files /dev/null and b/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/tool/ResourceParser$TextAppearanceResources.class differ
diff --git a/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/tool/ResourceParser$WidgetBgResources.class b/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/tool/ResourceParser$WidgetBgResources.class
new file mode 100644
index 0000000..9c8b59d
Binary files /dev/null and b/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/tool/ResourceParser$WidgetBgResources.class differ
diff --git a/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/tool/ResourceParser.class b/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/tool/ResourceParser.class
new file mode 100644
index 0000000..c4b0bea
Binary files /dev/null and b/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/tool/ResourceParser.class differ
diff --git a/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/tool/ScreenUtils.class b/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/tool/ScreenUtils.class
new file mode 100644
index 0000000..4229c01
Binary files /dev/null and b/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/tool/ScreenUtils.class differ
diff --git a/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/AlarmAlertActivity.class b/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/AlarmAlertActivity.class
new file mode 100644
index 0000000..dbf7fd9
Binary files /dev/null and b/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/AlarmAlertActivity.class differ
diff --git a/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/AlarmInitReceiver.class b/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/AlarmInitReceiver.class
new file mode 100644
index 0000000..d5771d0
Binary files /dev/null and b/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/AlarmInitReceiver.class differ
diff --git a/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/AlarmReceiver.class b/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/AlarmReceiver.class
new file mode 100644
index 0000000..b29a318
Binary files /dev/null and b/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/AlarmReceiver.class differ
diff --git a/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/DateTimePicker$1.class b/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/DateTimePicker$1.class
new file mode 100644
index 0000000..1927e68
Binary files /dev/null and b/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/DateTimePicker$1.class differ
diff --git a/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/DateTimePicker$2.class b/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/DateTimePicker$2.class
new file mode 100644
index 0000000..6359086
Binary files /dev/null and b/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/DateTimePicker$2.class differ
diff --git a/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/DateTimePicker$3.class b/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/DateTimePicker$3.class
new file mode 100644
index 0000000..1e6db2c
Binary files /dev/null and b/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/DateTimePicker$3.class differ
diff --git a/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/DateTimePicker$4.class b/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/DateTimePicker$4.class
new file mode 100644
index 0000000..54c442c
Binary files /dev/null and b/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/DateTimePicker$4.class differ
diff --git a/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/DateTimePicker$OnDateTimeChangedListener.class b/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/DateTimePicker$OnDateTimeChangedListener.class
new file mode 100644
index 0000000..4f59cba
Binary files /dev/null and b/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/DateTimePicker$OnDateTimeChangedListener.class differ
diff --git a/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/DateTimePicker.class b/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/DateTimePicker.class
new file mode 100644
index 0000000..94d1ed5
Binary files /dev/null and b/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/DateTimePicker.class differ
diff --git a/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/DateTimePickerDialog$1.class b/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/DateTimePickerDialog$1.class
new file mode 100644
index 0000000..cebe2a3
Binary files /dev/null and b/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/DateTimePickerDialog$1.class differ
diff --git a/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/DateTimePickerDialog$OnDateTimeSetListener.class b/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/DateTimePickerDialog$OnDateTimeSetListener.class
new file mode 100644
index 0000000..e4b9fdc
Binary files /dev/null and b/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/DateTimePickerDialog$OnDateTimeSetListener.class differ
diff --git a/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/DateTimePickerDialog.class b/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/DateTimePickerDialog.class
new file mode 100644
index 0000000..8183d4d
Binary files /dev/null and b/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/DateTimePickerDialog.class differ
diff --git a/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/DropdownMenu$1.class b/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/DropdownMenu$1.class
new file mode 100644
index 0000000..7db192e
Binary files /dev/null and b/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/DropdownMenu$1.class differ
diff --git a/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/DropdownMenu.class b/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/DropdownMenu.class
new file mode 100644
index 0000000..235aad1
Binary files /dev/null and b/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/DropdownMenu.class differ
diff --git a/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/FoldersListAdapter$FolderListItem.class b/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/FoldersListAdapter$FolderListItem.class
new file mode 100644
index 0000000..f329be3
Binary files /dev/null and b/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/FoldersListAdapter$FolderListItem.class differ
diff --git a/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/FoldersListAdapter.class b/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/FoldersListAdapter.class
new file mode 100644
index 0000000..615b8f4
Binary files /dev/null and b/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/FoldersListAdapter.class differ
diff --git a/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/GestureSetting$1$1.class b/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/GestureSetting$1$1.class
new file mode 100644
index 0000000..016fea8
Binary files /dev/null and b/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/GestureSetting$1$1.class differ
diff --git a/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/GestureSetting$1$2.class b/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/GestureSetting$1$2.class
new file mode 100644
index 0000000..62af3a9
Binary files /dev/null and b/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/GestureSetting$1$2.class differ
diff --git a/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/GestureSetting$1.class b/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/GestureSetting$1.class
new file mode 100644
index 0000000..a3c5014
Binary files /dev/null and b/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/GestureSetting$1.class differ
diff --git a/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/GestureSetting.class b/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/GestureSetting.class
new file mode 100644
index 0000000..e319aa7
Binary files /dev/null and b/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/GestureSetting.class differ
diff --git a/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/MyBoard$1.class b/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/MyBoard$1.class
new file mode 100644
index 0000000..5899140
Binary files /dev/null and b/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/MyBoard$1.class differ
diff --git a/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/MyBoard.class b/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/MyBoard.class
new file mode 100644
index 0000000..3f10e4c
Binary files /dev/null and b/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/MyBoard.class differ
diff --git a/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/NoteEditActivity$1.class b/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/NoteEditActivity$1.class
new file mode 100644
index 0000000..415953e
Binary files /dev/null and b/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/NoteEditActivity$1.class differ
diff --git a/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/NoteEditActivity$2.class b/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/NoteEditActivity$2.class
new file mode 100644
index 0000000..c715118
Binary files /dev/null and b/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/NoteEditActivity$2.class differ
diff --git a/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/NoteEditActivity$3.class b/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/NoteEditActivity$3.class
new file mode 100644
index 0000000..1863aa2
Binary files /dev/null and b/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/NoteEditActivity$3.class differ
diff --git a/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/NoteEditActivity$4.class b/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/NoteEditActivity$4.class
new file mode 100644
index 0000000..0c682de
Binary files /dev/null and b/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/NoteEditActivity$4.class differ
diff --git a/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/NoteEditActivity$5.class b/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/NoteEditActivity$5.class
new file mode 100644
index 0000000..0292263
Binary files /dev/null and b/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/NoteEditActivity$5.class differ
diff --git a/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/NoteEditActivity$6.class b/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/NoteEditActivity$6.class
new file mode 100644
index 0000000..4ecf807
Binary files /dev/null and b/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/NoteEditActivity$6.class differ
diff --git a/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/NoteEditActivity$7.class b/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/NoteEditActivity$7.class
new file mode 100644
index 0000000..dee8255
Binary files /dev/null and b/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/NoteEditActivity$7.class differ
diff --git a/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/NoteEditActivity$HeadViewHolder.class b/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/NoteEditActivity$HeadViewHolder.class
new file mode 100644
index 0000000..8ee7eb3
Binary files /dev/null and b/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/NoteEditActivity$HeadViewHolder.class differ
diff --git a/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/NoteEditActivity.class b/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/NoteEditActivity.class
new file mode 100644
index 0000000..c2a74db
Binary files /dev/null and b/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/NoteEditActivity.class differ
diff --git a/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/NoteEditText$1.class b/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/NoteEditText$1.class
new file mode 100644
index 0000000..ac84a18
Binary files /dev/null and b/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/NoteEditText$1.class differ
diff --git a/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/NoteEditText$OnTextViewChangeListener.class b/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/NoteEditText$OnTextViewChangeListener.class
new file mode 100644
index 0000000..2ff02fa
Binary files /dev/null and b/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/NoteEditText$OnTextViewChangeListener.class differ
diff --git a/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/NoteEditText.class b/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/NoteEditText.class
new file mode 100644
index 0000000..c11a81e
Binary files /dev/null and b/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/NoteEditText.class differ
diff --git a/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/NoteItemData.class b/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/NoteItemData.class
new file mode 100644
index 0000000..bad4631
Binary files /dev/null and b/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/NoteItemData.class differ
diff --git a/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/NotesListActivity$1.class b/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/NotesListActivity$1.class
new file mode 100644
index 0000000..304fa66
Binary files /dev/null and b/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/NotesListActivity$1.class differ
diff --git a/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/NotesListActivity$10.class b/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/NotesListActivity$10.class
new file mode 100644
index 0000000..6194c68
Binary files /dev/null and b/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/NotesListActivity$10.class differ
diff --git a/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/NotesListActivity$11.class b/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/NotesListActivity$11.class
new file mode 100644
index 0000000..fe4df0a
Binary files /dev/null and b/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/NotesListActivity$11.class differ
diff --git a/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/NotesListActivity$12.class b/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/NotesListActivity$12.class
new file mode 100644
index 0000000..6ea395d
Binary files /dev/null and b/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/NotesListActivity$12.class differ
diff --git a/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/NotesListActivity$13.class b/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/NotesListActivity$13.class
new file mode 100644
index 0000000..398bfa4
Binary files /dev/null and b/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/NotesListActivity$13.class differ
diff --git a/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/NotesListActivity$14.class b/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/NotesListActivity$14.class
new file mode 100644
index 0000000..5db6a8a
Binary files /dev/null and b/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/NotesListActivity$14.class differ
diff --git a/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/NotesListActivity$2.class b/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/NotesListActivity$2.class
new file mode 100644
index 0000000..d674241
Binary files /dev/null and b/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/NotesListActivity$2.class differ
diff --git a/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/NotesListActivity$3.class b/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/NotesListActivity$3.class
new file mode 100644
index 0000000..b8407ff
Binary files /dev/null and b/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/NotesListActivity$3.class differ
diff --git a/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/NotesListActivity$4.class b/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/NotesListActivity$4.class
new file mode 100644
index 0000000..ee14844
Binary files /dev/null and b/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/NotesListActivity$4.class differ
diff --git a/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/NotesListActivity$5.class b/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/NotesListActivity$5.class
new file mode 100644
index 0000000..b408ae5
Binary files /dev/null and b/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/NotesListActivity$5.class differ
diff --git a/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/NotesListActivity$6.class b/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/NotesListActivity$6.class
new file mode 100644
index 0000000..8b94995
Binary files /dev/null and b/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/NotesListActivity$6.class differ
diff --git a/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/NotesListActivity$7.class b/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/NotesListActivity$7.class
new file mode 100644
index 0000000..2a39121
Binary files /dev/null and b/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/NotesListActivity$7.class differ
diff --git a/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/NotesListActivity$8.class b/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/NotesListActivity$8.class
new file mode 100644
index 0000000..3776b5f
Binary files /dev/null and b/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/NotesListActivity$8.class differ
diff --git a/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/NotesListActivity$9.class b/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/NotesListActivity$9.class
new file mode 100644
index 0000000..79e15ee
Binary files /dev/null and b/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/NotesListActivity$9.class differ
diff --git a/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/NotesListActivity$BackgroundQueryHandler.class b/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/NotesListActivity$BackgroundQueryHandler.class
new file mode 100644
index 0000000..9a12bcb
Binary files /dev/null and b/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/NotesListActivity$BackgroundQueryHandler.class differ
diff --git a/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/NotesListActivity$ListEditState.class b/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/NotesListActivity$ListEditState.class
new file mode 100644
index 0000000..428dd5e
Binary files /dev/null and b/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/NotesListActivity$ListEditState.class differ
diff --git a/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/NotesListActivity$ModeCallback$1.class b/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/NotesListActivity$ModeCallback$1.class
new file mode 100644
index 0000000..e084e3a
Binary files /dev/null and b/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/NotesListActivity$ModeCallback$1.class differ
diff --git a/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/NotesListActivity$ModeCallback$2.class b/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/NotesListActivity$ModeCallback$2.class
new file mode 100644
index 0000000..0c445bb
Binary files /dev/null and b/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/NotesListActivity$ModeCallback$2.class differ
diff --git a/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/NotesListActivity$ModeCallback.class b/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/NotesListActivity$ModeCallback.class
new file mode 100644
index 0000000..ec5f481
Binary files /dev/null and b/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/NotesListActivity$ModeCallback.class differ
diff --git a/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/NotesListActivity$NewNoteOnTouchListener.class b/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/NotesListActivity$NewNoteOnTouchListener.class
new file mode 100644
index 0000000..1b387d0
Binary files /dev/null and b/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/NotesListActivity$NewNoteOnTouchListener.class differ
diff --git a/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/NotesListActivity$OnListItemClickListener.class b/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/NotesListActivity$OnListItemClickListener.class
new file mode 100644
index 0000000..aecb4cc
Binary files /dev/null and b/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/NotesListActivity$OnListItemClickListener.class differ
diff --git a/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/NotesListActivity$gestureOverlayListener.class b/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/NotesListActivity$gestureOverlayListener.class
new file mode 100644
index 0000000..92a44ac
Binary files /dev/null and b/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/NotesListActivity$gestureOverlayListener.class differ
diff --git a/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/NotesListActivity$gesturelistener.class b/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/NotesListActivity$gesturelistener.class
new file mode 100644
index 0000000..6887193
Binary files /dev/null and b/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/NotesListActivity$gesturelistener.class differ
diff --git a/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/NotesListActivity.class b/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/NotesListActivity.class
new file mode 100644
index 0000000..b5a129b
Binary files /dev/null and b/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/NotesListActivity.class differ
diff --git a/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/NotesListAdapter$AppWidgetAttribute.class b/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/NotesListAdapter$AppWidgetAttribute.class
new file mode 100644
index 0000000..cadf825
Binary files /dev/null and b/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/NotesListAdapter$AppWidgetAttribute.class differ
diff --git a/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/NotesListAdapter.class b/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/NotesListAdapter.class
new file mode 100644
index 0000000..c971264
Binary files /dev/null and b/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/NotesListAdapter.class differ
diff --git a/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/NotesListItem.class b/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/NotesListItem.class
new file mode 100644
index 0000000..9eae967
Binary files /dev/null and b/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/NotesListItem.class differ
diff --git a/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/NotesPreferenceActivity$1.class b/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/NotesPreferenceActivity$1.class
new file mode 100644
index 0000000..b22dd88
Binary files /dev/null and b/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/NotesPreferenceActivity$1.class differ
diff --git a/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/NotesPreferenceActivity$2.class b/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/NotesPreferenceActivity$2.class
new file mode 100644
index 0000000..0c7337f
Binary files /dev/null and b/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/NotesPreferenceActivity$2.class differ
diff --git a/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/NotesPreferenceActivity$3.class b/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/NotesPreferenceActivity$3.class
new file mode 100644
index 0000000..ce34948
Binary files /dev/null and b/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/NotesPreferenceActivity$3.class differ
diff --git a/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/NotesPreferenceActivity$4.class b/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/NotesPreferenceActivity$4.class
new file mode 100644
index 0000000..395b163
Binary files /dev/null and b/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/NotesPreferenceActivity$4.class differ
diff --git a/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/NotesPreferenceActivity$5.class b/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/NotesPreferenceActivity$5.class
new file mode 100644
index 0000000..0af1db5
Binary files /dev/null and b/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/NotesPreferenceActivity$5.class differ
diff --git a/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/NotesPreferenceActivity$6.class b/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/NotesPreferenceActivity$6.class
new file mode 100644
index 0000000..8edfb2e
Binary files /dev/null and b/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/NotesPreferenceActivity$6.class differ
diff --git a/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/NotesPreferenceActivity$7.class b/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/NotesPreferenceActivity$7.class
new file mode 100644
index 0000000..c0da799
Binary files /dev/null and b/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/NotesPreferenceActivity$7.class differ
diff --git a/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/NotesPreferenceActivity$8.class b/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/NotesPreferenceActivity$8.class
new file mode 100644
index 0000000..2e83310
Binary files /dev/null and b/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/NotesPreferenceActivity$8.class differ
diff --git a/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/NotesPreferenceActivity$GTaskReceiver.class b/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/NotesPreferenceActivity$GTaskReceiver.class
new file mode 100644
index 0000000..7eaed74
Binary files /dev/null and b/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/NotesPreferenceActivity$GTaskReceiver.class differ
diff --git a/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/NotesPreferenceActivity.class b/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/NotesPreferenceActivity.class
new file mode 100644
index 0000000..e7f6783
Binary files /dev/null and b/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/NotesPreferenceActivity.class differ
diff --git a/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/widget/NoteWidgetProvider.class b/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/widget/NoteWidgetProvider.class
new file mode 100644
index 0000000..dd3e825
Binary files /dev/null and b/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/widget/NoteWidgetProvider.class differ
diff --git a/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/widget/NoteWidgetProvider_2x.class b/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/widget/NoteWidgetProvider_2x.class
new file mode 100644
index 0000000..362aa05
Binary files /dev/null and b/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/widget/NoteWidgetProvider_2x.class differ
diff --git a/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/widget/NoteWidgetProvider_4x.class b/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/widget/NoteWidgetProvider_4x.class
new file mode 100644
index 0000000..5c2dc61
Binary files /dev/null and b/src/src/app/build/intermediates/javac/debug/classes/net/micode/notes/widget/NoteWidgetProvider_4x.class differ
diff --git a/src/src/app/build/intermediates/javac/debugAndroidTest/classes/net/micode/notes/test/BuildConfig.class b/src/src/app/build/intermediates/javac/debugAndroidTest/classes/net/micode/notes/test/BuildConfig.class
new file mode 100644
index 0000000..af3a424
Binary files /dev/null and b/src/src/app/build/intermediates/javac/debugAndroidTest/classes/net/micode/notes/test/BuildConfig.class differ
diff --git a/src/src/app/build/intermediates/manifest_merge_blame_file/debug/manifest-merger-blame-debug-report.txt b/src/src/app/build/intermediates/manifest_merge_blame_file/debug/manifest-merger-blame-debug-report.txt
new file mode 100644
index 0000000..84dc411
--- /dev/null
+++ b/src/src/app/build/intermediates/manifest_merge_blame_file/debug/manifest-merger-blame-debug-report.txt
@@ -0,0 +1,306 @@
+1
+2
+17
+22
+23 E:\Note\src\app\src\main\AndroidManifest.xml
+25 android:targetSdkVersion="28" />
+25-->E:\Note\src\app\src\main\AndroidManifest.xml
+26
+27
+27-->E:\Note\src\app\src\main\AndroidManifest.xml:25:5-81
+27-->E:\Note\src\app\src\main\AndroidManifest.xml:25:22-78
+28
+28-->E:\Note\src\app\src\main\AndroidManifest.xml:26:5-88
+28-->E:\Note\src\app\src\main\AndroidManifest.xml:26:22-85
+29
+29-->E:\Note\src\app\src\main\AndroidManifest.xml:27:5-67
+29-->E:\Note\src\app\src\main\AndroidManifest.xml:27:22-64
+30
+30-->E:\Note\src\app\src\main\AndroidManifest.xml:28:5-72
+30-->E:\Note\src\app\src\main\AndroidManifest.xml:28:22-69
+31
+31-->E:\Note\src\app\src\main\AndroidManifest.xml:29:5-74
+31-->E:\Note\src\app\src\main\AndroidManifest.xml:29:22-71
+32
+32-->E:\Note\src\app\src\main\AndroidManifest.xml:30:5-80
+32-->E:\Note\src\app\src\main\AndroidManifest.xml:30:22-77
+33
+33-->E:\Note\src\app\src\main\AndroidManifest.xml:31:5-71
+33-->E:\Note\src\app\src\main\AndroidManifest.xml:31:22-68
+34
+34-->E:\Note\src\app\src\main\AndroidManifest.xml:32:5-74
+34-->E:\Note\src\app\src\main\AndroidManifest.xml:32:22-71
+35
+35-->E:\Note\src\app\src\main\AndroidManifest.xml:33:5-81
+35-->E:\Note\src\app\src\main\AndroidManifest.xml:33:22-78
+36
+36-->E:\Note\src\app\src\main\AndroidManifest.xml:34:5-70
+36-->E:\Note\src\app\src\main\AndroidManifest.xml:34:22-68
+37
+37-->E:\Note\src\app\src\main\AndroidManifest.xml:36:5-78
+37-->E:\Note\src\app\src\main\AndroidManifest.xml:36:22-76
+38
+38-->E:\Note\src\app\src\main\AndroidManifest.xml:37:5-80
+38-->E:\Note\src\app\src\main\AndroidManifest.xml:37:22-78
+39
+40 E:\Note\src\app\src\main\AndroidManifest.xml:39:5-165:19
+41 android:appComponentFactory="androidx.core.app.CoreComponentFactory"
+41-->[androidx.core:core:1.0.0] C:\Users\彭\.gradle\caches\transforms-2\files-2.1\6d11613c3b6a00a9ea456b5609ec43f7\core-1.0.0\AndroidManifest.xml:22:18-86
+42 android:debuggable="true"
+43 android:icon="@drawable/icon_app"
+43-->E:\Note\src\app\src\main\AndroidManifest.xml:40:9-42
+44 android:label="@string/app_name"
+44-->E:\Note\src\app\src\main\AndroidManifest.xml:41:9-41
+45 android:testOnly="true" >
+46 E:\Note\src\app\src\main\AndroidManifest.xml:42:9-55:20
+47 android:name="net.micode.notes.ui.NotesListActivity"
+47-->E:\Note\src\app\src\main\AndroidManifest.xml:43:13-49
+48 android:configChanges="keyboardHidden|orientation|screenSize"
+48-->E:\Note\src\app\src\main\AndroidManifest.xml:44:13-74
+49 android:label="@string/app_name"
+49-->E:\Note\src\app\src\main\AndroidManifest.xml:45:13-45
+50 android:launchMode="singleTop"
+50-->E:\Note\src\app\src\main\AndroidManifest.xml:46:13-43
+51 android:theme="@style/NoteTheme"
+51-->E:\Note\src\app\src\main\AndroidManifest.xml:47:13-45
+52 android:windowSoftInputMode="adjustPan" >
+52-->E:\Note\src\app\src\main\AndroidManifest.xml:48:13-52
+53
+54
+55
+55-->E:\Note\src\app\src\main\AndroidManifest.xml:50:13-53:29
+56
+56-->E:\Note\src\app\src\main\AndroidManifest.xml:51:17-69
+56-->E:\Note\src\app\src\main\AndroidManifest.xml:51:25-66
+57
+58
+58-->E:\Note\src\app\src\main\AndroidManifest.xml:52:17-77
+58-->E:\Note\src\app\src\main\AndroidManifest.xml:52:27-74
+59
+60
+61 E:\Note\src\app\src\main\AndroidManifest.xml:57:9-85:20
+62 android:name="net.micode.notes.ui.NoteEditActivity"
+62-->E:\Note\src\app\src\main\AndroidManifest.xml:58:13-48
+63 android:configChanges="keyboardHidden|orientation|screenSize"
+63-->E:\Note\src\app\src\main\AndroidManifest.xml:59:13-74
+64 android:launchMode="singleTop"
+64-->E:\Note\src\app\src\main\AndroidManifest.xml:60:13-43
+65 android:theme="@style/NoteTheme" >
+65-->E:\Note\src\app\src\main\AndroidManifest.xml:61:13-45
+66
+66-->E:\Note\src\app\src\main\AndroidManifest.xml:63:13-68:29
+67
+67-->E:\Note\src\app\src\main\AndroidManifest.xml:64:17-69
+67-->E:\Note\src\app\src\main\AndroidManifest.xml:64:25-66
+68
+69
+69-->E:\Note\src\app\src\main\AndroidManifest.xml:65:17-76
+69-->E:\Note\src\app\src\main\AndroidManifest.xml:65:27-73
+70
+71
+71-->E:\Note\src\app\src\main\AndroidManifest.xml:66:17-78
+71-->E:\Note\src\app\src\main\AndroidManifest.xml:66:23-75
+72
+72-->E:\Note\src\app\src\main\AndroidManifest.xml:66:17-78
+72-->E:\Note\src\app\src\main\AndroidManifest.xml:66:23-75
+73
+74
+74-->E:\Note\src\app\src\main\AndroidManifest.xml:70:13-75:29
+75
+75-->E:\Note\src\app\src\main\AndroidManifest.xml:71:17-79
+75-->E:\Note\src\app\src\main\AndroidManifest.xml:71:25-76
+76
+77
+77-->E:\Note\src\app\src\main\AndroidManifest.xml:65:17-76
+77-->E:\Note\src\app\src\main\AndroidManifest.xml:65:27-73
+78
+79
+79-->E:\Note\src\app\src\main\AndroidManifest.xml:66:17-78
+79-->E:\Note\src\app\src\main\AndroidManifest.xml:66:23-75
+80
+80-->E:\Note\src\app\src\main\AndroidManifest.xml:66:17-78
+80-->E:\Note\src\app\src\main\AndroidManifest.xml:66:23-75
+81
+82
+82-->E:\Note\src\app\src\main\AndroidManifest.xml:77:13-80:29
+83
+83-->E:\Note\src\app\src\main\AndroidManifest.xml:78:17-71
+83-->E:\Note\src\app\src\main\AndroidManifest.xml:78:25-68
+84
+85
+85-->E:\Note\src\app\src\main\AndroidManifest.xml:65:17-76
+85-->E:\Note\src\app\src\main\AndroidManifest.xml:65:27-73
+86
+87
+88 E:\Note\src\app\src\main\AndroidManifest.xml:82:13-84:54
+89 android:name="android.app.searchable"
+89-->E:\Note\src\app\src\main\AndroidManifest.xml:83:17-54
+90 android:resource="@xml/searchable" />
+90-->E:\Note\src\app\src\main\AndroidManifest.xml:84:17-51
+91
+92
+93 E:\Note\src\app\src\main\AndroidManifest.xml:87:9-90:43
+94 android:name="net.micode.notes.data.NotesProvider"
+94-->E:\Note\src\app\src\main\AndroidManifest.xml:88:13-63
+95 android:authorities="micode_notes"
+95-->E:\Note\src\app\src\main\AndroidManifest.xml:89:13-47
+96 android:multiprocess="true" />
+96-->E:\Note\src\app\src\main\AndroidManifest.xml:90:13-40
+97
+98 E:\Note\src\app\src\main\AndroidManifest.xml:92:9-104:20
+99 android:name="net.micode.notes.widget.NoteWidgetProvider_2x"
+99-->E:\Note\src\app\src\main\AndroidManifest.xml:93:13-57
+100 android:label="@string/app_widget2x2" >
+100-->E:\Note\src\app\src\main\AndroidManifest.xml:94:13-50
+101
+101-->E:\Note\src\app\src\main\AndroidManifest.xml:95:13-99:29
+102
+102-->E:\Note\src\app\src\main\AndroidManifest.xml:96:17-84
+102-->E:\Note\src\app\src\main\AndroidManifest.xml:96:25-81
+103
+103-->E:\Note\src\app\src\main\AndroidManifest.xml:97:17-85
+103-->E:\Note\src\app\src\main\AndroidManifest.xml:97:25-82
+104
+104-->E:\Note\src\app\src\main\AndroidManifest.xml:98:17-85
+104-->E:\Note\src\app\src\main\AndroidManifest.xml:98:25-82
+105
+106
+107 E:\Note\src\app\src\main\AndroidManifest.xml:101:13-103:58
+108 android:name="android.appwidget.provider"
+108-->E:\Note\src\app\src\main\AndroidManifest.xml:102:17-58
+109 android:resource="@xml/widget_2x_info" />
+109-->E:\Note\src\app\src\main\AndroidManifest.xml:103:17-55
+110
+111 E:\Note\src\app\src\main\AndroidManifest.xml:105:9-118:20
+112 android:name="net.micode.notes.widget.NoteWidgetProvider_4x"
+112-->E:\Note\src\app\src\main\AndroidManifest.xml:106:13-57
+113 android:label="@string/app_widget4x4" >
+113-->E:\Note\src\app\src\main\AndroidManifest.xml:107:13-50
+114
+114-->E:\Note\src\app\src\main\AndroidManifest.xml:95:13-99:29
+115
+115-->E:\Note\src\app\src\main\AndroidManifest.xml:96:17-84
+115-->E:\Note\src\app\src\main\AndroidManifest.xml:96:25-81
+116
+116-->E:\Note\src\app\src\main\AndroidManifest.xml:97:17-85
+116-->E:\Note\src\app\src\main\AndroidManifest.xml:97:25-82
+117
+117-->E:\Note\src\app\src\main\AndroidManifest.xml:98:17-85
+117-->E:\Note\src\app\src\main\AndroidManifest.xml:98:25-82
+118
+119
+120 E:\Note\src\app\src\main\AndroidManifest.xml:101:13-103:58
+121 android:name="android.appwidget.provider"
+121-->E:\Note\src\app\src\main\AndroidManifest.xml:102:17-58
+122 android:resource="@xml/widget_4x_info" />
+122-->E:\Note\src\app\src\main\AndroidManifest.xml:103:17-55
+123
+124
+124-->E:\Note\src\app\src\main\AndroidManifest.xml:120:9-124:20
+124-->E:\Note\src\app\src\main\AndroidManifest.xml:120:19-55
+125
+125-->E:\Note\src\app\src\main\AndroidManifest.xml:121:13-123:29
+126
+126-->E:\Note\src\app\src\main\AndroidManifest.xml:122:17-79
+126-->E:\Note\src\app\src\main\AndroidManifest.xml:122:25-76
+127
+128
+129 E:\Note\src\app\src\main\AndroidManifest.xml:126:9-129:20
+130 android:name="net.micode.notes.ui.AlarmReceiver"
+130-->E:\Note\src\app\src\main\AndroidManifest.xml:127:13-61
+131 android:process=":remote" >
+131-->E:\Note\src\app\src\main\AndroidManifest.xml:128:13-38
+132
+133
+134 E:\Note\src\app\src\main\AndroidManifest.xml:131:9-136:20
+135 android:name="net.micode.notes.ui.AlarmAlertActivity"
+135-->E:\Note\src\app\src\main\AndroidManifest.xml:132:13-50
+136 android:label="@string/app_name"
+136-->E:\Note\src\app\src\main\AndroidManifest.xml:133:13-45
+137 android:launchMode="singleInstance"
+137-->E:\Note\src\app\src\main\AndroidManifest.xml:134:13-48
+138 android:theme="@android:style/Theme.Holo.Wallpaper.NoTitleBar" >
+138-->E:\Note\src\app\src\main\AndroidManifest.xml:135:13-75
+139
+140 E:\Note\src\app\src\main\AndroidManifest.xml:137:9-142:20
+141 android:name="net.micode.notes.ui.MyBoard"
+141-->E:\Note\src\app\src\main\AndroidManifest.xml:138:13-39
+142 android:label="MyBoard"
+142-->E:\Note\src\app\src\main\AndroidManifest.xml:139:13-36
+143 android:launchMode="singleInstance"
+143-->E:\Note\src\app\src\main\AndroidManifest.xml:140:13-48
+144 android:theme="@android:style/Theme.Holo.Wallpaper.NoTitleBar" >
+144-->E:\Note\src\app\src\main\AndroidManifest.xml:141:13-75
+145
+146 E:\Note\src\app\src\main\AndroidManifest.xml:143:9-148:20
+147 android:name="net.micode.notes.ui.GestureSetting"
+147-->E:\Note\src\app\src\main\AndroidManifest.xml:144:13-46
+148 android:label="GestrueSetting"
+148-->E:\Note\src\app\src\main\AndroidManifest.xml:145:13-43
+149 android:launchMode="singleInstance"
+149-->E:\Note\src\app\src\main\AndroidManifest.xml:146:13-48
+150 android:theme="@android:style/Theme.Holo.Wallpaper.NoTitleBar" >
+150-->E:\Note\src\app\src\main\AndroidManifest.xml:147:13-75
+151
+152 E:\Note\src\app\src\main\AndroidManifest.xml:150:9-155:20
+153 android:name="net.micode.notes.ui.NotesPreferenceActivity"
+153-->E:\Note\src\app\src\main\AndroidManifest.xml:151:13-71
+154 android:label="@string/preferences_title"
+154-->E:\Note\src\app\src\main\AndroidManifest.xml:152:13-54
+155 android:launchMode="singleTop"
+155-->E:\Note\src\app\src\main\AndroidManifest.xml:153:13-43
+156 android:theme="@android:style/Theme.Holo.Light" >
+156-->E:\Note\src\app\src\main\AndroidManifest.xml:154:13-60
+157
+158
+159 E:\Note\src\app\src\main\AndroidManifest.xml:157:9-160:19
+160 android:name="net.micode.notes.gtask.remote.GTaskSyncService"
+160-->E:\Note\src\app\src\main\AndroidManifest.xml:158:13-74
+161 android:exported="false" >
+161-->E:\Note\src\app\src\main\AndroidManifest.xml:159:13-37
+162
+163
+164 E:\Note\src\app\src\main\AndroidManifest.xml:162:9-164:52
+165 android:name="android.app.default_searchable"
+165-->E:\Note\src\app\src\main\AndroidManifest.xml:163:13-58
+166 android:value=".ui.NoteEditActivity" />
+166-->E:\Note\src\app\src\main\AndroidManifest.xml:164:13-49
+167
+168
+169
diff --git a/src/src/app/build/intermediates/merged_java_res/debug/out.jar b/src/src/app/build/intermediates/merged_java_res/debug/out.jar
new file mode 100644
index 0000000..376e88e
Binary files /dev/null and b/src/src/app/build/intermediates/merged_java_res/debug/out.jar differ
diff --git a/src/src/app/build/intermediates/merged_manifests/debug/AndroidManifest.xml b/src/src/app/build/intermediates/merged_manifests/debug/AndroidManifest.xml
new file mode 100644
index 0000000..3fb6129
--- /dev/null
+++ b/src/src/app/build/intermediates/merged_manifests/debug/AndroidManifest.xml
@@ -0,0 +1,169 @@
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
\ No newline at end of file
diff --git a/src/src/app/build/intermediates/merged_manifests/debug/output.json b/src/src/app/build/intermediates/merged_manifests/debug/output.json
new file mode 100644
index 0000000..a68e415
--- /dev/null
+++ b/src/src/app/build/intermediates/merged_manifests/debug/output.json
@@ -0,0 +1,28 @@
+{
+ "version": 1,
+ "applicationId": "net.micode.notes",
+ "variantType": "BASE_APK",
+ "elements": [
+ {
+ "outputType": {
+ "type": "MERGED_MANIFESTS"
+ },
+ "apkData": {
+ "type": "MAIN",
+ "splits": [],
+ "versionCode": 1,
+ "versionName": "0.1",
+ "outputFile": "app-debug.apk",
+ "fullName": "debug",
+ "baseName": "debug",
+ "dirName": ""
+ },
+ "path": "AndroidManifest.xml",
+ "properties": {
+ "packageId": "net.micode.notes",
+ "split": "",
+ "minSdkVersion": "14"
+ }
+ }
+ ]
+}
\ No newline at end of file
diff --git a/src/src/app/build/intermediates/merged_manifests/debugAndroidTest/AndroidManifest.xml b/src/src/app/build/intermediates/merged_manifests/debugAndroidTest/AndroidManifest.xml
new file mode 100644
index 0000000..f85f865
--- /dev/null
+++ b/src/src/app/build/intermediates/merged_manifests/debugAndroidTest/AndroidManifest.xml
@@ -0,0 +1,16 @@
+
+
+
+
+
+
+
+
+
+
+
diff --git a/src/src/app/build/intermediates/merged_manifests/debugAndroidTest/output.json b/src/src/app/build/intermediates/merged_manifests/debugAndroidTest/output.json
new file mode 100644
index 0000000..e5420bc
--- /dev/null
+++ b/src/src/app/build/intermediates/merged_manifests/debugAndroidTest/output.json
@@ -0,0 +1,23 @@
+{
+ "version": 1,
+ "applicationId": "net.micode.notes.test",
+ "variantType": "ANDROID_TEST",
+ "elements": [
+ {
+ "outputType": {
+ "type": "MERGED_MANIFESTS"
+ },
+ "apkData": {
+ "type": "MAIN",
+ "splits": [],
+ "versionCode": -1,
+ "outputFile": "app-debug-androidTest.apk",
+ "fullName": "debugAndroidTest",
+ "baseName": "debug-androidTest",
+ "dirName": ""
+ },
+ "path": "AndroidManifest.xml",
+ "properties": {}
+ }
+ ]
+}
\ No newline at end of file
diff --git a/src/src/app/build/intermediates/metadata_feature_manifest/debug/metadata-feature/output.json b/src/src/app/build/intermediates/metadata_feature_manifest/debug/metadata-feature/output.json
new file mode 100644
index 0000000..c2a24e3
--- /dev/null
+++ b/src/src/app/build/intermediates/metadata_feature_manifest/debug/metadata-feature/output.json
@@ -0,0 +1,24 @@
+{
+ "version": 1,
+ "applicationId": "net.micode.notes",
+ "variantType": "BASE_APK",
+ "elements": [
+ {
+ "outputType": {
+ "type": "METADATA_FEATURE_MANIFEST"
+ },
+ "apkData": {
+ "type": "MAIN",
+ "splits": [],
+ "versionCode": 1,
+ "versionName": "0.1",
+ "outputFile": "app-debug.apk",
+ "fullName": "debug",
+ "baseName": "debug",
+ "dirName": ""
+ },
+ "path": "AndroidManifest.xml",
+ "properties": {}
+ }
+ ]
+}
\ No newline at end of file
diff --git a/src/src/app/build/intermediates/navigation_json/debug/navigation.json b/src/src/app/build/intermediates/navigation_json/debug/navigation.json
new file mode 100644
index 0000000..0637a08
--- /dev/null
+++ b/src/src/app/build/intermediates/navigation_json/debug/navigation.json
@@ -0,0 +1 @@
+[]
\ No newline at end of file
diff --git a/src/src/app/build/intermediates/processed_res/debug/out/output.json b/src/src/app/build/intermediates/processed_res/debug/out/output.json
new file mode 100644
index 0000000..512068d
--- /dev/null
+++ b/src/src/app/build/intermediates/processed_res/debug/out/output.json
@@ -0,0 +1,28 @@
+{
+ "version": 1,
+ "applicationId": "net.micode.notes",
+ "variantType": "BASE_APK",
+ "elements": [
+ {
+ "outputType": {
+ "type": "PROCESSED_RES"
+ },
+ "apkData": {
+ "type": "MAIN",
+ "splits": [],
+ "versionCode": 1,
+ "versionName": "0.1",
+ "outputFile": "app-debug.apk",
+ "fullName": "debug",
+ "baseName": "debug",
+ "dirName": ""
+ },
+ "path": "resources-debug.ap_",
+ "properties": {
+ "packageId": "net.micode.notes",
+ "split": "",
+ "minSdkVersion": "14"
+ }
+ }
+ ]
+}
\ No newline at end of file
diff --git a/src/src/app/build/intermediates/processed_res/debug/out/resources-debug.ap_ b/src/src/app/build/intermediates/processed_res/debug/out/resources-debug.ap_
new file mode 100644
index 0000000..5dbbcee
Binary files /dev/null and b/src/src/app/build/intermediates/processed_res/debug/out/resources-debug.ap_ differ
diff --git a/src/src/app/build/intermediates/processed_res/debugAndroidTest/out/output.json b/src/src/app/build/intermediates/processed_res/debugAndroidTest/out/output.json
new file mode 100644
index 0000000..bf73840
--- /dev/null
+++ b/src/src/app/build/intermediates/processed_res/debugAndroidTest/out/output.json
@@ -0,0 +1,23 @@
+{
+ "version": 1,
+ "applicationId": "net.micode.notes.test",
+ "variantType": "ANDROID_TEST",
+ "elements": [
+ {
+ "outputType": {
+ "type": "PROCESSED_RES"
+ },
+ "apkData": {
+ "type": "MAIN",
+ "splits": [],
+ "versionCode": -1,
+ "outputFile": "app-debug-androidTest.apk",
+ "fullName": "debugAndroidTest",
+ "baseName": "debug-androidTest",
+ "dirName": ""
+ },
+ "path": "resources-debugAndroidTest.ap_",
+ "properties": {}
+ }
+ ]
+}
\ No newline at end of file
diff --git a/src/src/app/build/intermediates/processed_res/debugAndroidTest/out/resources-debugAndroidTest.ap_ b/src/src/app/build/intermediates/processed_res/debugAndroidTest/out/resources-debugAndroidTest.ap_
new file mode 100644
index 0000000..e31b785
Binary files /dev/null and b/src/src/app/build/intermediates/processed_res/debugAndroidTest/out/resources-debugAndroidTest.ap_ differ
diff --git a/src/src/app/build/intermediates/project_dex_archive/debug/out/e66553f93f601aa59c9b907dbe76c3a1fba3eb5d6ff2261d1a2b40bf40c6c9a5_0.jar b/src/src/app/build/intermediates/project_dex_archive/debug/out/e66553f93f601aa59c9b907dbe76c3a1fba3eb5d6ff2261d1a2b40bf40c6c9a5_0.jar
new file mode 100644
index 0000000..4180eb1
Binary files /dev/null and b/src/src/app/build/intermediates/project_dex_archive/debug/out/e66553f93f601aa59c9b907dbe76c3a1fba3eb5d6ff2261d1a2b40bf40c6c9a5_0.jar differ
diff --git a/src/src/app/build/intermediates/project_dex_archive/debug/out/e66553f93f601aa59c9b907dbe76c3a1fba3eb5d6ff2261d1a2b40bf40c6c9a5_1.jar b/src/src/app/build/intermediates/project_dex_archive/debug/out/e66553f93f601aa59c9b907dbe76c3a1fba3eb5d6ff2261d1a2b40bf40c6c9a5_1.jar
new file mode 100644
index 0000000..e510f24
Binary files /dev/null and b/src/src/app/build/intermediates/project_dex_archive/debug/out/e66553f93f601aa59c9b907dbe76c3a1fba3eb5d6ff2261d1a2b40bf40c6c9a5_1.jar differ
diff --git a/src/src/app/build/intermediates/project_dex_archive/debug/out/e66553f93f601aa59c9b907dbe76c3a1fba3eb5d6ff2261d1a2b40bf40c6c9a5_2.jar b/src/src/app/build/intermediates/project_dex_archive/debug/out/e66553f93f601aa59c9b907dbe76c3a1fba3eb5d6ff2261d1a2b40bf40c6c9a5_2.jar
new file mode 100644
index 0000000..5895c96
Binary files /dev/null and b/src/src/app/build/intermediates/project_dex_archive/debug/out/e66553f93f601aa59c9b907dbe76c3a1fba3eb5d6ff2261d1a2b40bf40c6c9a5_2.jar differ
diff --git a/src/src/app/build/intermediates/project_dex_archive/debug/out/e66553f93f601aa59c9b907dbe76c3a1fba3eb5d6ff2261d1a2b40bf40c6c9a5_3.jar b/src/src/app/build/intermediates/project_dex_archive/debug/out/e66553f93f601aa59c9b907dbe76c3a1fba3eb5d6ff2261d1a2b40bf40c6c9a5_3.jar
new file mode 100644
index 0000000..6963da9
Binary files /dev/null and b/src/src/app/build/intermediates/project_dex_archive/debug/out/e66553f93f601aa59c9b907dbe76c3a1fba3eb5d6ff2261d1a2b40bf40c6c9a5_3.jar differ
diff --git a/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/BuildConfig.dex b/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/BuildConfig.dex
new file mode 100644
index 0000000..9673c85
Binary files /dev/null and b/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/BuildConfig.dex differ
diff --git a/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/data/Contact.dex b/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/data/Contact.dex
new file mode 100644
index 0000000..75ec813
Binary files /dev/null and b/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/data/Contact.dex differ
diff --git a/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/data/Notes$CallNote.dex b/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/data/Notes$CallNote.dex
new file mode 100644
index 0000000..5b6ab1e
Binary files /dev/null and b/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/data/Notes$CallNote.dex differ
diff --git a/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/data/Notes$DataColumns.dex b/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/data/Notes$DataColumns.dex
new file mode 100644
index 0000000..255f10a
Binary files /dev/null and b/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/data/Notes$DataColumns.dex differ
diff --git a/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/data/Notes$DataConstants.dex b/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/data/Notes$DataConstants.dex
new file mode 100644
index 0000000..2a2b130
Binary files /dev/null and b/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/data/Notes$DataConstants.dex differ
diff --git a/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/data/Notes$NoteColumns.dex b/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/data/Notes$NoteColumns.dex
new file mode 100644
index 0000000..839805e
Binary files /dev/null and b/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/data/Notes$NoteColumns.dex differ
diff --git a/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/data/Notes$TextNote.dex b/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/data/Notes$TextNote.dex
new file mode 100644
index 0000000..f2a41d7
Binary files /dev/null and b/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/data/Notes$TextNote.dex differ
diff --git a/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/data/Notes.dex b/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/data/Notes.dex
new file mode 100644
index 0000000..658dea9
Binary files /dev/null and b/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/data/Notes.dex differ
diff --git a/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/data/NotesDatabaseHelper$TABLE.dex b/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/data/NotesDatabaseHelper$TABLE.dex
new file mode 100644
index 0000000..ef5fbf3
Binary files /dev/null and b/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/data/NotesDatabaseHelper$TABLE.dex differ
diff --git a/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/data/NotesDatabaseHelper.dex b/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/data/NotesDatabaseHelper.dex
new file mode 100644
index 0000000..ee6fcb1
Binary files /dev/null and b/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/data/NotesDatabaseHelper.dex differ
diff --git a/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/data/NotesProvider.dex b/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/data/NotesProvider.dex
new file mode 100644
index 0000000..efd904a
Binary files /dev/null and b/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/data/NotesProvider.dex differ
diff --git a/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/gtask/data/MetaData.dex b/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/gtask/data/MetaData.dex
new file mode 100644
index 0000000..7d774da
Binary files /dev/null and b/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/gtask/data/MetaData.dex differ
diff --git a/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/gtask/data/Node.dex b/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/gtask/data/Node.dex
new file mode 100644
index 0000000..4e4d086
Binary files /dev/null and b/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/gtask/data/Node.dex differ
diff --git a/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/gtask/data/SqlData.dex b/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/gtask/data/SqlData.dex
new file mode 100644
index 0000000..b77ca6a
Binary files /dev/null and b/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/gtask/data/SqlData.dex differ
diff --git a/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/gtask/data/SqlNote.dex b/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/gtask/data/SqlNote.dex
new file mode 100644
index 0000000..ed4f8e3
Binary files /dev/null and b/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/gtask/data/SqlNote.dex differ
diff --git a/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/gtask/data/Task.dex b/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/gtask/data/Task.dex
new file mode 100644
index 0000000..8f52210
Binary files /dev/null and b/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/gtask/data/Task.dex differ
diff --git a/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/gtask/data/TaskList.dex b/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/gtask/data/TaskList.dex
new file mode 100644
index 0000000..7ae78e9
Binary files /dev/null and b/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/gtask/data/TaskList.dex differ
diff --git a/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/gtask/exception/ActionFailureException.dex b/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/gtask/exception/ActionFailureException.dex
new file mode 100644
index 0000000..d29f7ef
Binary files /dev/null and b/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/gtask/exception/ActionFailureException.dex differ
diff --git a/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/gtask/exception/NetworkFailureException.dex b/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/gtask/exception/NetworkFailureException.dex
new file mode 100644
index 0000000..a23ddcb
Binary files /dev/null and b/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/gtask/exception/NetworkFailureException.dex differ
diff --git a/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/gtask/remote/GTaskASyncTask$1.dex b/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/gtask/remote/GTaskASyncTask$1.dex
new file mode 100644
index 0000000..905e44e
Binary files /dev/null and b/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/gtask/remote/GTaskASyncTask$1.dex differ
diff --git a/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/gtask/remote/GTaskASyncTask$OnCompleteListener.dex b/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/gtask/remote/GTaskASyncTask$OnCompleteListener.dex
new file mode 100644
index 0000000..1a49021
Binary files /dev/null and b/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/gtask/remote/GTaskASyncTask$OnCompleteListener.dex differ
diff --git a/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/gtask/remote/GTaskASyncTask.dex b/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/gtask/remote/GTaskASyncTask.dex
new file mode 100644
index 0000000..7ecde32
Binary files /dev/null and b/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/gtask/remote/GTaskASyncTask.dex differ
diff --git a/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/gtask/remote/GTaskClient.dex b/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/gtask/remote/GTaskClient.dex
new file mode 100644
index 0000000..ef4f692
Binary files /dev/null and b/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/gtask/remote/GTaskClient.dex differ
diff --git a/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/gtask/remote/GTaskManager.dex b/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/gtask/remote/GTaskManager.dex
new file mode 100644
index 0000000..f2c4b2a
Binary files /dev/null and b/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/gtask/remote/GTaskManager.dex differ
diff --git a/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/gtask/remote/GTaskSyncService$1.dex b/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/gtask/remote/GTaskSyncService$1.dex
new file mode 100644
index 0000000..5da71cb
Binary files /dev/null and b/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/gtask/remote/GTaskSyncService$1.dex differ
diff --git a/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/gtask/remote/GTaskSyncService.dex b/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/gtask/remote/GTaskSyncService.dex
new file mode 100644
index 0000000..7b832c3
Binary files /dev/null and b/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/gtask/remote/GTaskSyncService.dex differ
diff --git a/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/model/Note$NoteData.dex b/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/model/Note$NoteData.dex
new file mode 100644
index 0000000..d60c5ed
Binary files /dev/null and b/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/model/Note$NoteData.dex differ
diff --git a/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/model/Note.dex b/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/model/Note.dex
new file mode 100644
index 0000000..9a05ca7
Binary files /dev/null and b/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/model/Note.dex differ
diff --git a/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/model/WorkingNote$NoteSettingChangedListener.dex b/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/model/WorkingNote$NoteSettingChangedListener.dex
new file mode 100644
index 0000000..961490d
Binary files /dev/null and b/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/model/WorkingNote$NoteSettingChangedListener.dex differ
diff --git a/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/model/WorkingNote.dex b/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/model/WorkingNote.dex
new file mode 100644
index 0000000..f953244
Binary files /dev/null and b/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/model/WorkingNote.dex differ
diff --git a/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/tool/BackupUtils$TextExport.dex b/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/tool/BackupUtils$TextExport.dex
new file mode 100644
index 0000000..3c27aab
Binary files /dev/null and b/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/tool/BackupUtils$TextExport.dex differ
diff --git a/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/tool/BackupUtils.dex b/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/tool/BackupUtils.dex
new file mode 100644
index 0000000..499ab2c
Binary files /dev/null and b/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/tool/BackupUtils.dex differ
diff --git a/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/tool/DataUtils.dex b/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/tool/DataUtils.dex
new file mode 100644
index 0000000..913da50
Binary files /dev/null and b/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/tool/DataUtils.dex differ
diff --git a/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/tool/GTaskStringUtils.dex b/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/tool/GTaskStringUtils.dex
new file mode 100644
index 0000000..a159d48
Binary files /dev/null and b/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/tool/GTaskStringUtils.dex differ
diff --git a/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/tool/ImageUtils.dex b/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/tool/ImageUtils.dex
new file mode 100644
index 0000000..3199b5a
Binary files /dev/null and b/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/tool/ImageUtils.dex differ
diff --git a/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/tool/ResourceParser$NoteBgResources.dex b/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/tool/ResourceParser$NoteBgResources.dex
new file mode 100644
index 0000000..47904be
Binary files /dev/null and b/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/tool/ResourceParser$NoteBgResources.dex differ
diff --git a/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/tool/ResourceParser$NoteItemBgResources.dex b/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/tool/ResourceParser$NoteItemBgResources.dex
new file mode 100644
index 0000000..161f0d3
Binary files /dev/null and b/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/tool/ResourceParser$NoteItemBgResources.dex differ
diff --git a/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/tool/ResourceParser$TextAppearanceResources.dex b/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/tool/ResourceParser$TextAppearanceResources.dex
new file mode 100644
index 0000000..bf214ab
Binary files /dev/null and b/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/tool/ResourceParser$TextAppearanceResources.dex differ
diff --git a/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/tool/ResourceParser$WidgetBgResources.dex b/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/tool/ResourceParser$WidgetBgResources.dex
new file mode 100644
index 0000000..579d6ff
Binary files /dev/null and b/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/tool/ResourceParser$WidgetBgResources.dex differ
diff --git a/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/tool/ResourceParser.dex b/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/tool/ResourceParser.dex
new file mode 100644
index 0000000..a591078
Binary files /dev/null and b/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/tool/ResourceParser.dex differ
diff --git a/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/tool/ScreenUtils.dex b/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/tool/ScreenUtils.dex
new file mode 100644
index 0000000..47aa30c
Binary files /dev/null and b/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/tool/ScreenUtils.dex differ
diff --git a/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/ui/AlarmAlertActivity.dex b/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/ui/AlarmAlertActivity.dex
new file mode 100644
index 0000000..bb04950
Binary files /dev/null and b/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/ui/AlarmAlertActivity.dex differ
diff --git a/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/ui/AlarmInitReceiver.dex b/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/ui/AlarmInitReceiver.dex
new file mode 100644
index 0000000..b6452ff
Binary files /dev/null and b/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/ui/AlarmInitReceiver.dex differ
diff --git a/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/ui/AlarmReceiver.dex b/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/ui/AlarmReceiver.dex
new file mode 100644
index 0000000..4d48216
Binary files /dev/null and b/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/ui/AlarmReceiver.dex differ
diff --git a/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/ui/DateTimePicker$1.dex b/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/ui/DateTimePicker$1.dex
new file mode 100644
index 0000000..455357c
Binary files /dev/null and b/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/ui/DateTimePicker$1.dex differ
diff --git a/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/ui/DateTimePicker$2.dex b/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/ui/DateTimePicker$2.dex
new file mode 100644
index 0000000..b4d1662
Binary files /dev/null and b/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/ui/DateTimePicker$2.dex differ
diff --git a/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/ui/DateTimePicker$3.dex b/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/ui/DateTimePicker$3.dex
new file mode 100644
index 0000000..a3c8a92
Binary files /dev/null and b/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/ui/DateTimePicker$3.dex differ
diff --git a/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/ui/DateTimePicker$4.dex b/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/ui/DateTimePicker$4.dex
new file mode 100644
index 0000000..b07a56b
Binary files /dev/null and b/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/ui/DateTimePicker$4.dex differ
diff --git a/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/ui/DateTimePicker$OnDateTimeChangedListener.dex b/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/ui/DateTimePicker$OnDateTimeChangedListener.dex
new file mode 100644
index 0000000..640f6c0
Binary files /dev/null and b/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/ui/DateTimePicker$OnDateTimeChangedListener.dex differ
diff --git a/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/ui/DateTimePicker.dex b/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/ui/DateTimePicker.dex
new file mode 100644
index 0000000..6c7cb3e
Binary files /dev/null and b/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/ui/DateTimePicker.dex differ
diff --git a/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/ui/DateTimePickerDialog$1.dex b/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/ui/DateTimePickerDialog$1.dex
new file mode 100644
index 0000000..3dd2070
Binary files /dev/null and b/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/ui/DateTimePickerDialog$1.dex differ
diff --git a/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/ui/DateTimePickerDialog$OnDateTimeSetListener.dex b/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/ui/DateTimePickerDialog$OnDateTimeSetListener.dex
new file mode 100644
index 0000000..855ecae
Binary files /dev/null and b/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/ui/DateTimePickerDialog$OnDateTimeSetListener.dex differ
diff --git a/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/ui/DateTimePickerDialog.dex b/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/ui/DateTimePickerDialog.dex
new file mode 100644
index 0000000..055ef2a
Binary files /dev/null and b/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/ui/DateTimePickerDialog.dex differ
diff --git a/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/ui/DropdownMenu$1.dex b/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/ui/DropdownMenu$1.dex
new file mode 100644
index 0000000..915ba18
Binary files /dev/null and b/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/ui/DropdownMenu$1.dex differ
diff --git a/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/ui/DropdownMenu.dex b/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/ui/DropdownMenu.dex
new file mode 100644
index 0000000..d34f9b6
Binary files /dev/null and b/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/ui/DropdownMenu.dex differ
diff --git a/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/ui/FoldersListAdapter$FolderListItem.dex b/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/ui/FoldersListAdapter$FolderListItem.dex
new file mode 100644
index 0000000..04b5bee
Binary files /dev/null and b/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/ui/FoldersListAdapter$FolderListItem.dex differ
diff --git a/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/ui/FoldersListAdapter.dex b/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/ui/FoldersListAdapter.dex
new file mode 100644
index 0000000..ce24232
Binary files /dev/null and b/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/ui/FoldersListAdapter.dex differ
diff --git a/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/ui/GestureSetting$1$1.dex b/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/ui/GestureSetting$1$1.dex
new file mode 100644
index 0000000..103901e
Binary files /dev/null and b/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/ui/GestureSetting$1$1.dex differ
diff --git a/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/ui/GestureSetting$1$2.dex b/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/ui/GestureSetting$1$2.dex
new file mode 100644
index 0000000..686e04a
Binary files /dev/null and b/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/ui/GestureSetting$1$2.dex differ
diff --git a/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/ui/GestureSetting$1.dex b/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/ui/GestureSetting$1.dex
new file mode 100644
index 0000000..f437962
Binary files /dev/null and b/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/ui/GestureSetting$1.dex differ
diff --git a/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/ui/GestureSetting.dex b/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/ui/GestureSetting.dex
new file mode 100644
index 0000000..87c0052
Binary files /dev/null and b/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/ui/GestureSetting.dex differ
diff --git a/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/ui/MyBoard$1.dex b/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/ui/MyBoard$1.dex
new file mode 100644
index 0000000..5499c0d
Binary files /dev/null and b/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/ui/MyBoard$1.dex differ
diff --git a/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/ui/MyBoard.dex b/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/ui/MyBoard.dex
new file mode 100644
index 0000000..e70852c
Binary files /dev/null and b/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/ui/MyBoard.dex differ
diff --git a/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/ui/NoteEditActivity$1.dex b/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/ui/NoteEditActivity$1.dex
new file mode 100644
index 0000000..4873e9b
Binary files /dev/null and b/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/ui/NoteEditActivity$1.dex differ
diff --git a/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/ui/NoteEditActivity$2.dex b/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/ui/NoteEditActivity$2.dex
new file mode 100644
index 0000000..95654f3
Binary files /dev/null and b/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/ui/NoteEditActivity$2.dex differ
diff --git a/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/ui/NoteEditActivity$3.dex b/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/ui/NoteEditActivity$3.dex
new file mode 100644
index 0000000..84a7bca
Binary files /dev/null and b/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/ui/NoteEditActivity$3.dex differ
diff --git a/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/ui/NoteEditActivity$4.dex b/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/ui/NoteEditActivity$4.dex
new file mode 100644
index 0000000..83346eb
Binary files /dev/null and b/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/ui/NoteEditActivity$4.dex differ
diff --git a/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/ui/NoteEditActivity$5.dex b/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/ui/NoteEditActivity$5.dex
new file mode 100644
index 0000000..ef1e56f
Binary files /dev/null and b/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/ui/NoteEditActivity$5.dex differ
diff --git a/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/ui/NoteEditActivity$6.dex b/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/ui/NoteEditActivity$6.dex
new file mode 100644
index 0000000..29f70c3
Binary files /dev/null and b/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/ui/NoteEditActivity$6.dex differ
diff --git a/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/ui/NoteEditActivity$7.dex b/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/ui/NoteEditActivity$7.dex
new file mode 100644
index 0000000..58dde34
Binary files /dev/null and b/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/ui/NoteEditActivity$7.dex differ
diff --git a/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/ui/NoteEditActivity$HeadViewHolder.dex b/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/ui/NoteEditActivity$HeadViewHolder.dex
new file mode 100644
index 0000000..745f833
Binary files /dev/null and b/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/ui/NoteEditActivity$HeadViewHolder.dex differ
diff --git a/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/ui/NoteEditActivity.dex b/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/ui/NoteEditActivity.dex
new file mode 100644
index 0000000..acf4eb4
Binary files /dev/null and b/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/ui/NoteEditActivity.dex differ
diff --git a/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/ui/NoteEditText$1.dex b/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/ui/NoteEditText$1.dex
new file mode 100644
index 0000000..7471a99
Binary files /dev/null and b/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/ui/NoteEditText$1.dex differ
diff --git a/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/ui/NoteEditText$OnTextViewChangeListener.dex b/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/ui/NoteEditText$OnTextViewChangeListener.dex
new file mode 100644
index 0000000..a10b711
Binary files /dev/null and b/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/ui/NoteEditText$OnTextViewChangeListener.dex differ
diff --git a/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/ui/NoteEditText.dex b/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/ui/NoteEditText.dex
new file mode 100644
index 0000000..346af9d
Binary files /dev/null and b/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/ui/NoteEditText.dex differ
diff --git a/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/ui/NoteItemData.dex b/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/ui/NoteItemData.dex
new file mode 100644
index 0000000..b77fb39
Binary files /dev/null and b/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/ui/NoteItemData.dex differ
diff --git a/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/ui/NotesListActivity$1.dex b/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/ui/NotesListActivity$1.dex
new file mode 100644
index 0000000..1c04ff9
Binary files /dev/null and b/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/ui/NotesListActivity$1.dex differ
diff --git a/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/ui/NotesListActivity$10.dex b/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/ui/NotesListActivity$10.dex
new file mode 100644
index 0000000..d76df0c
Binary files /dev/null and b/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/ui/NotesListActivity$10.dex differ
diff --git a/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/ui/NotesListActivity$11.dex b/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/ui/NotesListActivity$11.dex
new file mode 100644
index 0000000..9626cef
Binary files /dev/null and b/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/ui/NotesListActivity$11.dex differ
diff --git a/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/ui/NotesListActivity$12.dex b/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/ui/NotesListActivity$12.dex
new file mode 100644
index 0000000..60ed7ea
Binary files /dev/null and b/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/ui/NotesListActivity$12.dex differ
diff --git a/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/ui/NotesListActivity$13.dex b/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/ui/NotesListActivity$13.dex
new file mode 100644
index 0000000..b0c0098
Binary files /dev/null and b/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/ui/NotesListActivity$13.dex differ
diff --git a/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/ui/NotesListActivity$14.dex b/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/ui/NotesListActivity$14.dex
new file mode 100644
index 0000000..321a492
Binary files /dev/null and b/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/ui/NotesListActivity$14.dex differ
diff --git a/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/ui/NotesListActivity$2.dex b/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/ui/NotesListActivity$2.dex
new file mode 100644
index 0000000..31cdf15
Binary files /dev/null and b/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/ui/NotesListActivity$2.dex differ
diff --git a/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/ui/NotesListActivity$3.dex b/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/ui/NotesListActivity$3.dex
new file mode 100644
index 0000000..58696d9
Binary files /dev/null and b/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/ui/NotesListActivity$3.dex differ
diff --git a/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/ui/NotesListActivity$4.dex b/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/ui/NotesListActivity$4.dex
new file mode 100644
index 0000000..6a09120
Binary files /dev/null and b/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/ui/NotesListActivity$4.dex differ
diff --git a/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/ui/NotesListActivity$5.dex b/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/ui/NotesListActivity$5.dex
new file mode 100644
index 0000000..91aaa22
Binary files /dev/null and b/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/ui/NotesListActivity$5.dex differ
diff --git a/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/ui/NotesListActivity$6.dex b/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/ui/NotesListActivity$6.dex
new file mode 100644
index 0000000..85265a8
Binary files /dev/null and b/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/ui/NotesListActivity$6.dex differ
diff --git a/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/ui/NotesListActivity$7.dex b/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/ui/NotesListActivity$7.dex
new file mode 100644
index 0000000..4f2a5be
Binary files /dev/null and b/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/ui/NotesListActivity$7.dex differ
diff --git a/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/ui/NotesListActivity$8.dex b/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/ui/NotesListActivity$8.dex
new file mode 100644
index 0000000..dc7d24b
Binary files /dev/null and b/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/ui/NotesListActivity$8.dex differ
diff --git a/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/ui/NotesListActivity$9.dex b/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/ui/NotesListActivity$9.dex
new file mode 100644
index 0000000..3252b74
Binary files /dev/null and b/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/ui/NotesListActivity$9.dex differ
diff --git a/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/ui/NotesListActivity$BackgroundQueryHandler.dex b/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/ui/NotesListActivity$BackgroundQueryHandler.dex
new file mode 100644
index 0000000..cd52c99
Binary files /dev/null and b/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/ui/NotesListActivity$BackgroundQueryHandler.dex differ
diff --git a/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/ui/NotesListActivity$ListEditState.dex b/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/ui/NotesListActivity$ListEditState.dex
new file mode 100644
index 0000000..3f82069
Binary files /dev/null and b/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/ui/NotesListActivity$ListEditState.dex differ
diff --git a/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/ui/NotesListActivity$ModeCallback$1.dex b/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/ui/NotesListActivity$ModeCallback$1.dex
new file mode 100644
index 0000000..d5834b3
Binary files /dev/null and b/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/ui/NotesListActivity$ModeCallback$1.dex differ
diff --git a/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/ui/NotesListActivity$ModeCallback$2.dex b/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/ui/NotesListActivity$ModeCallback$2.dex
new file mode 100644
index 0000000..6fcd065
Binary files /dev/null and b/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/ui/NotesListActivity$ModeCallback$2.dex differ
diff --git a/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/ui/NotesListActivity$ModeCallback.dex b/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/ui/NotesListActivity$ModeCallback.dex
new file mode 100644
index 0000000..a606ccd
Binary files /dev/null and b/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/ui/NotesListActivity$ModeCallback.dex differ
diff --git a/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/ui/NotesListActivity$NewNoteOnTouchListener.dex b/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/ui/NotesListActivity$NewNoteOnTouchListener.dex
new file mode 100644
index 0000000..bb4a49b
Binary files /dev/null and b/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/ui/NotesListActivity$NewNoteOnTouchListener.dex differ
diff --git a/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/ui/NotesListActivity$OnListItemClickListener.dex b/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/ui/NotesListActivity$OnListItemClickListener.dex
new file mode 100644
index 0000000..98de959
Binary files /dev/null and b/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/ui/NotesListActivity$OnListItemClickListener.dex differ
diff --git a/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/ui/NotesListActivity$gestureOverlayListener.dex b/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/ui/NotesListActivity$gestureOverlayListener.dex
new file mode 100644
index 0000000..459d1eb
Binary files /dev/null and b/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/ui/NotesListActivity$gestureOverlayListener.dex differ
diff --git a/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/ui/NotesListActivity$gesturelistener.dex b/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/ui/NotesListActivity$gesturelistener.dex
new file mode 100644
index 0000000..b2a18fe
Binary files /dev/null and b/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/ui/NotesListActivity$gesturelistener.dex differ
diff --git a/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/ui/NotesListActivity.dex b/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/ui/NotesListActivity.dex
new file mode 100644
index 0000000..09055bf
Binary files /dev/null and b/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/ui/NotesListActivity.dex differ
diff --git a/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/ui/NotesListAdapter$AppWidgetAttribute.dex b/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/ui/NotesListAdapter$AppWidgetAttribute.dex
new file mode 100644
index 0000000..cc30f32
Binary files /dev/null and b/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/ui/NotesListAdapter$AppWidgetAttribute.dex differ
diff --git a/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/ui/NotesListAdapter.dex b/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/ui/NotesListAdapter.dex
new file mode 100644
index 0000000..14b44b7
Binary files /dev/null and b/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/ui/NotesListAdapter.dex differ
diff --git a/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/ui/NotesListItem.dex b/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/ui/NotesListItem.dex
new file mode 100644
index 0000000..a955681
Binary files /dev/null and b/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/ui/NotesListItem.dex differ
diff --git a/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/ui/NotesPreferenceActivity$1.dex b/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/ui/NotesPreferenceActivity$1.dex
new file mode 100644
index 0000000..472c62d
Binary files /dev/null and b/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/ui/NotesPreferenceActivity$1.dex differ
diff --git a/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/ui/NotesPreferenceActivity$2.dex b/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/ui/NotesPreferenceActivity$2.dex
new file mode 100644
index 0000000..356f2ba
Binary files /dev/null and b/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/ui/NotesPreferenceActivity$2.dex differ
diff --git a/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/ui/NotesPreferenceActivity$3.dex b/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/ui/NotesPreferenceActivity$3.dex
new file mode 100644
index 0000000..aee04a0
Binary files /dev/null and b/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/ui/NotesPreferenceActivity$3.dex differ
diff --git a/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/ui/NotesPreferenceActivity$4.dex b/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/ui/NotesPreferenceActivity$4.dex
new file mode 100644
index 0000000..3d1498c
Binary files /dev/null and b/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/ui/NotesPreferenceActivity$4.dex differ
diff --git a/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/ui/NotesPreferenceActivity$5.dex b/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/ui/NotesPreferenceActivity$5.dex
new file mode 100644
index 0000000..29138fa
Binary files /dev/null and b/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/ui/NotesPreferenceActivity$5.dex differ
diff --git a/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/ui/NotesPreferenceActivity$6.dex b/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/ui/NotesPreferenceActivity$6.dex
new file mode 100644
index 0000000..196f2c7
Binary files /dev/null and b/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/ui/NotesPreferenceActivity$6.dex differ
diff --git a/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/ui/NotesPreferenceActivity$7.dex b/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/ui/NotesPreferenceActivity$7.dex
new file mode 100644
index 0000000..635abde
Binary files /dev/null and b/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/ui/NotesPreferenceActivity$7.dex differ
diff --git a/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/ui/NotesPreferenceActivity$8.dex b/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/ui/NotesPreferenceActivity$8.dex
new file mode 100644
index 0000000..4503761
Binary files /dev/null and b/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/ui/NotesPreferenceActivity$8.dex differ
diff --git a/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/ui/NotesPreferenceActivity$GTaskReceiver.dex b/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/ui/NotesPreferenceActivity$GTaskReceiver.dex
new file mode 100644
index 0000000..46e034a
Binary files /dev/null and b/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/ui/NotesPreferenceActivity$GTaskReceiver.dex differ
diff --git a/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/ui/NotesPreferenceActivity.dex b/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/ui/NotesPreferenceActivity.dex
new file mode 100644
index 0000000..d713b15
Binary files /dev/null and b/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/ui/NotesPreferenceActivity.dex differ
diff --git a/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/widget/NoteWidgetProvider.dex b/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/widget/NoteWidgetProvider.dex
new file mode 100644
index 0000000..802c6fe
Binary files /dev/null and b/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/widget/NoteWidgetProvider.dex differ
diff --git a/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/widget/NoteWidgetProvider_2x.dex b/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/widget/NoteWidgetProvider_2x.dex
new file mode 100644
index 0000000..7b452e9
Binary files /dev/null and b/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/widget/NoteWidgetProvider_2x.dex differ
diff --git a/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/widget/NoteWidgetProvider_4x.dex b/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/widget/NoteWidgetProvider_4x.dex
new file mode 100644
index 0000000..98c7ca9
Binary files /dev/null and b/src/src/app/build/intermediates/project_dex_archive/debug/out/net/micode/notes/widget/NoteWidgetProvider_4x.dex differ
diff --git a/src/src/app/build/intermediates/res/merged/debug/color_primary_text_dark.xml.flat b/src/src/app/build/intermediates/res/merged/debug/color_primary_text_dark.xml.flat
new file mode 100644
index 0000000..22761e2
Binary files /dev/null and b/src/src/app/build/intermediates/res/merged/debug/color_primary_text_dark.xml.flat differ
diff --git a/src/src/app/build/intermediates/res/merged/debug/color_secondary_text_dark.xml.flat b/src/src/app/build/intermediates/res/merged/debug/color_secondary_text_dark.xml.flat
new file mode 100644
index 0000000..cb165e7
Binary files /dev/null and b/src/src/app/build/intermediates/res/merged/debug/color_secondary_text_dark.xml.flat differ
diff --git a/src/src/app/build/intermediates/res/merged/debug/drawable-hdpi_bg_btn_set_color.png.flat b/src/src/app/build/intermediates/res/merged/debug/drawable-hdpi_bg_btn_set_color.png.flat
new file mode 100644
index 0000000..c4fdd19
Binary files /dev/null and b/src/src/app/build/intermediates/res/merged/debug/drawable-hdpi_bg_btn_set_color.png.flat differ
diff --git a/src/src/app/build/intermediates/res/merged/debug/drawable-hdpi_bg_color_btn_mask.png.flat b/src/src/app/build/intermediates/res/merged/debug/drawable-hdpi_bg_color_btn_mask.png.flat
new file mode 100644
index 0000000..ab01938
Binary files /dev/null and b/src/src/app/build/intermediates/res/merged/debug/drawable-hdpi_bg_color_btn_mask.png.flat differ
diff --git a/src/src/app/build/intermediates/res/merged/debug/drawable-hdpi_call_record.png.flat b/src/src/app/build/intermediates/res/merged/debug/drawable-hdpi_call_record.png.flat
new file mode 100644
index 0000000..baf6025
Binary files /dev/null and b/src/src/app/build/intermediates/res/merged/debug/drawable-hdpi_call_record.png.flat differ
diff --git a/src/src/app/build/intermediates/res/merged/debug/drawable-hdpi_clock.png.flat b/src/src/app/build/intermediates/res/merged/debug/drawable-hdpi_clock.png.flat
new file mode 100644
index 0000000..6a89685
Binary files /dev/null and b/src/src/app/build/intermediates/res/merged/debug/drawable-hdpi_clock.png.flat differ
diff --git a/src/src/app/build/intermediates/res/merged/debug/drawable-hdpi_delete.png.flat b/src/src/app/build/intermediates/res/merged/debug/drawable-hdpi_delete.png.flat
new file mode 100644
index 0000000..40265b6
Binary files /dev/null and b/src/src/app/build/intermediates/res/merged/debug/drawable-hdpi_delete.png.flat differ
diff --git a/src/src/app/build/intermediates/res/merged/debug/drawable-hdpi_dropdown_icon.9.png.flat b/src/src/app/build/intermediates/res/merged/debug/drawable-hdpi_dropdown_icon.9.png.flat
new file mode 100644
index 0000000..320168a
Binary files /dev/null and b/src/src/app/build/intermediates/res/merged/debug/drawable-hdpi_dropdown_icon.9.png.flat differ
diff --git a/src/src/app/build/intermediates/res/merged/debug/drawable-hdpi_edit_blue.9.png.flat b/src/src/app/build/intermediates/res/merged/debug/drawable-hdpi_edit_blue.9.png.flat
new file mode 100644
index 0000000..c246a3a
Binary files /dev/null and b/src/src/app/build/intermediates/res/merged/debug/drawable-hdpi_edit_blue.9.png.flat differ
diff --git a/src/src/app/build/intermediates/res/merged/debug/drawable-hdpi_edit_green.9.png.flat b/src/src/app/build/intermediates/res/merged/debug/drawable-hdpi_edit_green.9.png.flat
new file mode 100644
index 0000000..91f2de8
Binary files /dev/null and b/src/src/app/build/intermediates/res/merged/debug/drawable-hdpi_edit_green.9.png.flat differ
diff --git a/src/src/app/build/intermediates/res/merged/debug/drawable-hdpi_edit_red.9.png.flat b/src/src/app/build/intermediates/res/merged/debug/drawable-hdpi_edit_red.9.png.flat
new file mode 100644
index 0000000..2542865
Binary files /dev/null and b/src/src/app/build/intermediates/res/merged/debug/drawable-hdpi_edit_red.9.png.flat differ
diff --git a/src/src/app/build/intermediates/res/merged/debug/drawable-hdpi_edit_title_blue.9.png.flat b/src/src/app/build/intermediates/res/merged/debug/drawable-hdpi_edit_title_blue.9.png.flat
new file mode 100644
index 0000000..eb216b2
Binary files /dev/null and b/src/src/app/build/intermediates/res/merged/debug/drawable-hdpi_edit_title_blue.9.png.flat differ
diff --git a/src/src/app/build/intermediates/res/merged/debug/drawable-hdpi_edit_title_green.9.png.flat b/src/src/app/build/intermediates/res/merged/debug/drawable-hdpi_edit_title_green.9.png.flat
new file mode 100644
index 0000000..1d70402
Binary files /dev/null and b/src/src/app/build/intermediates/res/merged/debug/drawable-hdpi_edit_title_green.9.png.flat differ
diff --git a/src/src/app/build/intermediates/res/merged/debug/drawable-hdpi_edit_title_red.9.png.flat b/src/src/app/build/intermediates/res/merged/debug/drawable-hdpi_edit_title_red.9.png.flat
new file mode 100644
index 0000000..1140420
Binary files /dev/null and b/src/src/app/build/intermediates/res/merged/debug/drawable-hdpi_edit_title_red.9.png.flat differ
diff --git a/src/src/app/build/intermediates/res/merged/debug/drawable-hdpi_edit_title_white.9.png.flat b/src/src/app/build/intermediates/res/merged/debug/drawable-hdpi_edit_title_white.9.png.flat
new file mode 100644
index 0000000..666789e
Binary files /dev/null and b/src/src/app/build/intermediates/res/merged/debug/drawable-hdpi_edit_title_white.9.png.flat differ
diff --git a/src/src/app/build/intermediates/res/merged/debug/drawable-hdpi_edit_title_yellow.9.png.flat b/src/src/app/build/intermediates/res/merged/debug/drawable-hdpi_edit_title_yellow.9.png.flat
new file mode 100644
index 0000000..10bd3ef
Binary files /dev/null and b/src/src/app/build/intermediates/res/merged/debug/drawable-hdpi_edit_title_yellow.9.png.flat differ
diff --git a/src/src/app/build/intermediates/res/merged/debug/drawable-hdpi_edit_white.9.png.flat b/src/src/app/build/intermediates/res/merged/debug/drawable-hdpi_edit_white.9.png.flat
new file mode 100644
index 0000000..270bbf8
Binary files /dev/null and b/src/src/app/build/intermediates/res/merged/debug/drawable-hdpi_edit_white.9.png.flat differ
diff --git a/src/src/app/build/intermediates/res/merged/debug/drawable-hdpi_edit_yellow.9.png.flat b/src/src/app/build/intermediates/res/merged/debug/drawable-hdpi_edit_yellow.9.png.flat
new file mode 100644
index 0000000..ce26426
Binary files /dev/null and b/src/src/app/build/intermediates/res/merged/debug/drawable-hdpi_edit_yellow.9.png.flat differ
diff --git a/src/src/app/build/intermediates/res/merged/debug/drawable-hdpi_font_large.png.flat b/src/src/app/build/intermediates/res/merged/debug/drawable-hdpi_font_large.png.flat
new file mode 100644
index 0000000..62088fc
Binary files /dev/null and b/src/src/app/build/intermediates/res/merged/debug/drawable-hdpi_font_large.png.flat differ
diff --git a/src/src/app/build/intermediates/res/merged/debug/drawable-hdpi_font_normal.png.flat b/src/src/app/build/intermediates/res/merged/debug/drawable-hdpi_font_normal.png.flat
new file mode 100644
index 0000000..fd8ed4b
Binary files /dev/null and b/src/src/app/build/intermediates/res/merged/debug/drawable-hdpi_font_normal.png.flat differ
diff --git a/src/src/app/build/intermediates/res/merged/debug/drawable-hdpi_font_size_selector_bg.9.png.flat b/src/src/app/build/intermediates/res/merged/debug/drawable-hdpi_font_size_selector_bg.9.png.flat
new file mode 100644
index 0000000..66adb15
Binary files /dev/null and b/src/src/app/build/intermediates/res/merged/debug/drawable-hdpi_font_size_selector_bg.9.png.flat differ
diff --git a/src/src/app/build/intermediates/res/merged/debug/drawable-hdpi_font_small.png.flat b/src/src/app/build/intermediates/res/merged/debug/drawable-hdpi_font_small.png.flat
new file mode 100644
index 0000000..3f10010
Binary files /dev/null and b/src/src/app/build/intermediates/res/merged/debug/drawable-hdpi_font_small.png.flat differ
diff --git a/src/src/app/build/intermediates/res/merged/debug/drawable-hdpi_font_super.png.flat b/src/src/app/build/intermediates/res/merged/debug/drawable-hdpi_font_super.png.flat
new file mode 100644
index 0000000..417c46c
Binary files /dev/null and b/src/src/app/build/intermediates/res/merged/debug/drawable-hdpi_font_super.png.flat differ
diff --git a/src/src/app/build/intermediates/res/merged/debug/drawable-hdpi_huaban.PNG.flat b/src/src/app/build/intermediates/res/merged/debug/drawable-hdpi_huaban.PNG.flat
new file mode 100644
index 0000000..66ac488
Binary files /dev/null and b/src/src/app/build/intermediates/res/merged/debug/drawable-hdpi_huaban.PNG.flat differ
diff --git a/src/src/app/build/intermediates/res/merged/debug/drawable-hdpi_icon_app.png.flat b/src/src/app/build/intermediates/res/merged/debug/drawable-hdpi_icon_app.png.flat
new file mode 100644
index 0000000..e32edf4
Binary files /dev/null and b/src/src/app/build/intermediates/res/merged/debug/drawable-hdpi_icon_app.png.flat differ
diff --git a/src/src/app/build/intermediates/res/merged/debug/drawable-hdpi_key.png.flat b/src/src/app/build/intermediates/res/merged/debug/drawable-hdpi_key.png.flat
new file mode 100644
index 0000000..1051d50
Binary files /dev/null and b/src/src/app/build/intermediates/res/merged/debug/drawable-hdpi_key.png.flat differ
diff --git a/src/src/app/build/intermediates/res/merged/debug/drawable-hdpi_list_background.png.flat b/src/src/app/build/intermediates/res/merged/debug/drawable-hdpi_list_background.png.flat
new file mode 100644
index 0000000..64acb14
Binary files /dev/null and b/src/src/app/build/intermediates/res/merged/debug/drawable-hdpi_list_background.png.flat differ
diff --git a/src/src/app/build/intermediates/res/merged/debug/drawable-hdpi_list_blue_down.9.png.flat b/src/src/app/build/intermediates/res/merged/debug/drawable-hdpi_list_blue_down.9.png.flat
new file mode 100644
index 0000000..03231f5
Binary files /dev/null and b/src/src/app/build/intermediates/res/merged/debug/drawable-hdpi_list_blue_down.9.png.flat differ
diff --git a/src/src/app/build/intermediates/res/merged/debug/drawable-hdpi_list_blue_middle.9.png.flat b/src/src/app/build/intermediates/res/merged/debug/drawable-hdpi_list_blue_middle.9.png.flat
new file mode 100644
index 0000000..272770f
Binary files /dev/null and b/src/src/app/build/intermediates/res/merged/debug/drawable-hdpi_list_blue_middle.9.png.flat differ
diff --git a/src/src/app/build/intermediates/res/merged/debug/drawable-hdpi_list_blue_single.9.png.flat b/src/src/app/build/intermediates/res/merged/debug/drawable-hdpi_list_blue_single.9.png.flat
new file mode 100644
index 0000000..4705830
Binary files /dev/null and b/src/src/app/build/intermediates/res/merged/debug/drawable-hdpi_list_blue_single.9.png.flat differ
diff --git a/src/src/app/build/intermediates/res/merged/debug/drawable-hdpi_list_blue_up.9.png.flat b/src/src/app/build/intermediates/res/merged/debug/drawable-hdpi_list_blue_up.9.png.flat
new file mode 100644
index 0000000..b56ef9a
Binary files /dev/null and b/src/src/app/build/intermediates/res/merged/debug/drawable-hdpi_list_blue_up.9.png.flat differ
diff --git a/src/src/app/build/intermediates/res/merged/debug/drawable-hdpi_list_folder.9.png.flat b/src/src/app/build/intermediates/res/merged/debug/drawable-hdpi_list_folder.9.png.flat
new file mode 100644
index 0000000..3eec5ef
Binary files /dev/null and b/src/src/app/build/intermediates/res/merged/debug/drawable-hdpi_list_folder.9.png.flat differ
diff --git a/src/src/app/build/intermediates/res/merged/debug/drawable-hdpi_list_footer_bg.9.png.flat b/src/src/app/build/intermediates/res/merged/debug/drawable-hdpi_list_footer_bg.9.png.flat
new file mode 100644
index 0000000..3dea301
Binary files /dev/null and b/src/src/app/build/intermediates/res/merged/debug/drawable-hdpi_list_footer_bg.9.png.flat differ
diff --git a/src/src/app/build/intermediates/res/merged/debug/drawable-hdpi_list_green_down.9.png.flat b/src/src/app/build/intermediates/res/merged/debug/drawable-hdpi_list_green_down.9.png.flat
new file mode 100644
index 0000000..f5629ad
Binary files /dev/null and b/src/src/app/build/intermediates/res/merged/debug/drawable-hdpi_list_green_down.9.png.flat differ
diff --git a/src/src/app/build/intermediates/res/merged/debug/drawable-hdpi_list_green_middle.9.png.flat b/src/src/app/build/intermediates/res/merged/debug/drawable-hdpi_list_green_middle.9.png.flat
new file mode 100644
index 0000000..4a8d417
Binary files /dev/null and b/src/src/app/build/intermediates/res/merged/debug/drawable-hdpi_list_green_middle.9.png.flat differ
diff --git a/src/src/app/build/intermediates/res/merged/debug/drawable-hdpi_list_green_single.9.png.flat b/src/src/app/build/intermediates/res/merged/debug/drawable-hdpi_list_green_single.9.png.flat
new file mode 100644
index 0000000..3b835b5
Binary files /dev/null and b/src/src/app/build/intermediates/res/merged/debug/drawable-hdpi_list_green_single.9.png.flat differ
diff --git a/src/src/app/build/intermediates/res/merged/debug/drawable-hdpi_list_green_up.9.png.flat b/src/src/app/build/intermediates/res/merged/debug/drawable-hdpi_list_green_up.9.png.flat
new file mode 100644
index 0000000..2caec89
Binary files /dev/null and b/src/src/app/build/intermediates/res/merged/debug/drawable-hdpi_list_green_up.9.png.flat differ
diff --git a/src/src/app/build/intermediates/res/merged/debug/drawable-hdpi_list_red_down.9.png.flat b/src/src/app/build/intermediates/res/merged/debug/drawable-hdpi_list_red_down.9.png.flat
new file mode 100644
index 0000000..8514244
Binary files /dev/null and b/src/src/app/build/intermediates/res/merged/debug/drawable-hdpi_list_red_down.9.png.flat differ
diff --git a/src/src/app/build/intermediates/res/merged/debug/drawable-hdpi_list_red_middle.9.png.flat b/src/src/app/build/intermediates/res/merged/debug/drawable-hdpi_list_red_middle.9.png.flat
new file mode 100644
index 0000000..04ee506
Binary files /dev/null and b/src/src/app/build/intermediates/res/merged/debug/drawable-hdpi_list_red_middle.9.png.flat differ
diff --git a/src/src/app/build/intermediates/res/merged/debug/drawable-hdpi_list_red_single.9.png.flat b/src/src/app/build/intermediates/res/merged/debug/drawable-hdpi_list_red_single.9.png.flat
new file mode 100644
index 0000000..993f86b
Binary files /dev/null and b/src/src/app/build/intermediates/res/merged/debug/drawable-hdpi_list_red_single.9.png.flat differ
diff --git a/src/src/app/build/intermediates/res/merged/debug/drawable-hdpi_list_red_up.9.png.flat b/src/src/app/build/intermediates/res/merged/debug/drawable-hdpi_list_red_up.9.png.flat
new file mode 100644
index 0000000..e80511d
Binary files /dev/null and b/src/src/app/build/intermediates/res/merged/debug/drawable-hdpi_list_red_up.9.png.flat differ
diff --git a/src/src/app/build/intermediates/res/merged/debug/drawable-hdpi_list_white_down.9.png.flat b/src/src/app/build/intermediates/res/merged/debug/drawable-hdpi_list_white_down.9.png.flat
new file mode 100644
index 0000000..5f4448f
Binary files /dev/null and b/src/src/app/build/intermediates/res/merged/debug/drawable-hdpi_list_white_down.9.png.flat differ
diff --git a/src/src/app/build/intermediates/res/merged/debug/drawable-hdpi_list_white_middle.9.png.flat b/src/src/app/build/intermediates/res/merged/debug/drawable-hdpi_list_white_middle.9.png.flat
new file mode 100644
index 0000000..c9cfa37
Binary files /dev/null and b/src/src/app/build/intermediates/res/merged/debug/drawable-hdpi_list_white_middle.9.png.flat differ
diff --git a/src/src/app/build/intermediates/res/merged/debug/drawable-hdpi_list_white_single.9.png.flat b/src/src/app/build/intermediates/res/merged/debug/drawable-hdpi_list_white_single.9.png.flat
new file mode 100644
index 0000000..9ddb77f
Binary files /dev/null and b/src/src/app/build/intermediates/res/merged/debug/drawable-hdpi_list_white_single.9.png.flat differ
diff --git a/src/src/app/build/intermediates/res/merged/debug/drawable-hdpi_list_white_up.9.png.flat b/src/src/app/build/intermediates/res/merged/debug/drawable-hdpi_list_white_up.9.png.flat
new file mode 100644
index 0000000..995ab70
Binary files /dev/null and b/src/src/app/build/intermediates/res/merged/debug/drawable-hdpi_list_white_up.9.png.flat differ
diff --git a/src/src/app/build/intermediates/res/merged/debug/drawable-hdpi_list_yellow_down.9.png.flat b/src/src/app/build/intermediates/res/merged/debug/drawable-hdpi_list_yellow_down.9.png.flat
new file mode 100644
index 0000000..cae4cd3
Binary files /dev/null and b/src/src/app/build/intermediates/res/merged/debug/drawable-hdpi_list_yellow_down.9.png.flat differ
diff --git a/src/src/app/build/intermediates/res/merged/debug/drawable-hdpi_list_yellow_middle.9.png.flat b/src/src/app/build/intermediates/res/merged/debug/drawable-hdpi_list_yellow_middle.9.png.flat
new file mode 100644
index 0000000..800a7a0
Binary files /dev/null and b/src/src/app/build/intermediates/res/merged/debug/drawable-hdpi_list_yellow_middle.9.png.flat differ
diff --git a/src/src/app/build/intermediates/res/merged/debug/drawable-hdpi_list_yellow_single.9.png.flat b/src/src/app/build/intermediates/res/merged/debug/drawable-hdpi_list_yellow_single.9.png.flat
new file mode 100644
index 0000000..c5db0e4
Binary files /dev/null and b/src/src/app/build/intermediates/res/merged/debug/drawable-hdpi_list_yellow_single.9.png.flat differ
diff --git a/src/src/app/build/intermediates/res/merged/debug/drawable-hdpi_list_yellow_up.9.png.flat b/src/src/app/build/intermediates/res/merged/debug/drawable-hdpi_list_yellow_up.9.png.flat
new file mode 100644
index 0000000..abd6020
Binary files /dev/null and b/src/src/app/build/intermediates/res/merged/debug/drawable-hdpi_list_yellow_up.9.png.flat differ
diff --git a/src/src/app/build/intermediates/res/merged/debug/drawable-hdpi_menu_delete.png.flat b/src/src/app/build/intermediates/res/merged/debug/drawable-hdpi_menu_delete.png.flat
new file mode 100644
index 0000000..11e6b58
Binary files /dev/null and b/src/src/app/build/intermediates/res/merged/debug/drawable-hdpi_menu_delete.png.flat differ
diff --git a/src/src/app/build/intermediates/res/merged/debug/drawable-hdpi_menu_move.png.flat b/src/src/app/build/intermediates/res/merged/debug/drawable-hdpi_menu_move.png.flat
new file mode 100644
index 0000000..946f6af
Binary files /dev/null and b/src/src/app/build/intermediates/res/merged/debug/drawable-hdpi_menu_move.png.flat differ
diff --git a/src/src/app/build/intermediates/res/merged/debug/drawable-hdpi_new_note_normal.png.flat b/src/src/app/build/intermediates/res/merged/debug/drawable-hdpi_new_note_normal.png.flat
new file mode 100644
index 0000000..ffcbf72
Binary files /dev/null and b/src/src/app/build/intermediates/res/merged/debug/drawable-hdpi_new_note_normal.png.flat differ
diff --git a/src/src/app/build/intermediates/res/merged/debug/drawable-hdpi_new_note_pressed.png.flat b/src/src/app/build/intermediates/res/merged/debug/drawable-hdpi_new_note_pressed.png.flat
new file mode 100644
index 0000000..77ce978
Binary files /dev/null and b/src/src/app/build/intermediates/res/merged/debug/drawable-hdpi_new_note_pressed.png.flat differ
diff --git a/src/src/app/build/intermediates/res/merged/debug/drawable-hdpi_note_edit_color_selector_panel.png.flat b/src/src/app/build/intermediates/res/merged/debug/drawable-hdpi_note_edit_color_selector_panel.png.flat
new file mode 100644
index 0000000..53fee1d
Binary files /dev/null and b/src/src/app/build/intermediates/res/merged/debug/drawable-hdpi_note_edit_color_selector_panel.png.flat differ
diff --git a/src/src/app/build/intermediates/res/merged/debug/drawable-hdpi_notification.png.flat b/src/src/app/build/intermediates/res/merged/debug/drawable-hdpi_notification.png.flat
new file mode 100644
index 0000000..b980999
Binary files /dev/null and b/src/src/app/build/intermediates/res/merged/debug/drawable-hdpi_notification.png.flat differ
diff --git a/src/src/app/build/intermediates/res/merged/debug/drawable-hdpi_search_result.png.flat b/src/src/app/build/intermediates/res/merged/debug/drawable-hdpi_search_result.png.flat
new file mode 100644
index 0000000..ef10446
Binary files /dev/null and b/src/src/app/build/intermediates/res/merged/debug/drawable-hdpi_search_result.png.flat differ
diff --git a/src/src/app/build/intermediates/res/merged/debug/drawable-hdpi_selected.png.flat b/src/src/app/build/intermediates/res/merged/debug/drawable-hdpi_selected.png.flat
new file mode 100644
index 0000000..ad99dd0
Binary files /dev/null and b/src/src/app/build/intermediates/res/merged/debug/drawable-hdpi_selected.png.flat differ
diff --git a/src/src/app/build/intermediates/res/merged/debug/drawable-hdpi_title_alert.png.flat b/src/src/app/build/intermediates/res/merged/debug/drawable-hdpi_title_alert.png.flat
new file mode 100644
index 0000000..d9b7c21
Binary files /dev/null and b/src/src/app/build/intermediates/res/merged/debug/drawable-hdpi_title_alert.png.flat differ
diff --git a/src/src/app/build/intermediates/res/merged/debug/drawable-hdpi_title_bar_bg.9.png.flat b/src/src/app/build/intermediates/res/merged/debug/drawable-hdpi_title_bar_bg.9.png.flat
new file mode 100644
index 0000000..45aca6f
Binary files /dev/null and b/src/src/app/build/intermediates/res/merged/debug/drawable-hdpi_title_bar_bg.9.png.flat differ
diff --git a/src/src/app/build/intermediates/res/merged/debug/drawable-hdpi_widget_2x_blue.png.flat b/src/src/app/build/intermediates/res/merged/debug/drawable-hdpi_widget_2x_blue.png.flat
new file mode 100644
index 0000000..536c6cf
Binary files /dev/null and b/src/src/app/build/intermediates/res/merged/debug/drawable-hdpi_widget_2x_blue.png.flat differ
diff --git a/src/src/app/build/intermediates/res/merged/debug/drawable-hdpi_widget_2x_green.png.flat b/src/src/app/build/intermediates/res/merged/debug/drawable-hdpi_widget_2x_green.png.flat
new file mode 100644
index 0000000..ee09a37
Binary files /dev/null and b/src/src/app/build/intermediates/res/merged/debug/drawable-hdpi_widget_2x_green.png.flat differ
diff --git a/src/src/app/build/intermediates/res/merged/debug/drawable-hdpi_widget_2x_red.png.flat b/src/src/app/build/intermediates/res/merged/debug/drawable-hdpi_widget_2x_red.png.flat
new file mode 100644
index 0000000..94132dc
Binary files /dev/null and b/src/src/app/build/intermediates/res/merged/debug/drawable-hdpi_widget_2x_red.png.flat differ
diff --git a/src/src/app/build/intermediates/res/merged/debug/drawable-hdpi_widget_2x_white.png.flat b/src/src/app/build/intermediates/res/merged/debug/drawable-hdpi_widget_2x_white.png.flat
new file mode 100644
index 0000000..1c64fbf
Binary files /dev/null and b/src/src/app/build/intermediates/res/merged/debug/drawable-hdpi_widget_2x_white.png.flat differ
diff --git a/src/src/app/build/intermediates/res/merged/debug/drawable-hdpi_widget_2x_yellow.png.flat b/src/src/app/build/intermediates/res/merged/debug/drawable-hdpi_widget_2x_yellow.png.flat
new file mode 100644
index 0000000..9415fba
Binary files /dev/null and b/src/src/app/build/intermediates/res/merged/debug/drawable-hdpi_widget_2x_yellow.png.flat differ
diff --git a/src/src/app/build/intermediates/res/merged/debug/drawable-hdpi_widget_4x_blue.png.flat b/src/src/app/build/intermediates/res/merged/debug/drawable-hdpi_widget_4x_blue.png.flat
new file mode 100644
index 0000000..fb4bc9e
Binary files /dev/null and b/src/src/app/build/intermediates/res/merged/debug/drawable-hdpi_widget_4x_blue.png.flat differ
diff --git a/src/src/app/build/intermediates/res/merged/debug/drawable-hdpi_widget_4x_green.png.flat b/src/src/app/build/intermediates/res/merged/debug/drawable-hdpi_widget_4x_green.png.flat
new file mode 100644
index 0000000..4d3f9d0
Binary files /dev/null and b/src/src/app/build/intermediates/res/merged/debug/drawable-hdpi_widget_4x_green.png.flat differ
diff --git a/src/src/app/build/intermediates/res/merged/debug/drawable-hdpi_widget_4x_red.png.flat b/src/src/app/build/intermediates/res/merged/debug/drawable-hdpi_widget_4x_red.png.flat
new file mode 100644
index 0000000..79a3931
Binary files /dev/null and b/src/src/app/build/intermediates/res/merged/debug/drawable-hdpi_widget_4x_red.png.flat differ
diff --git a/src/src/app/build/intermediates/res/merged/debug/drawable-hdpi_widget_4x_white.png.flat b/src/src/app/build/intermediates/res/merged/debug/drawable-hdpi_widget_4x_white.png.flat
new file mode 100644
index 0000000..5cd11f8
Binary files /dev/null and b/src/src/app/build/intermediates/res/merged/debug/drawable-hdpi_widget_4x_white.png.flat differ
diff --git a/src/src/app/build/intermediates/res/merged/debug/drawable-hdpi_widget_4x_yellow.png.flat b/src/src/app/build/intermediates/res/merged/debug/drawable-hdpi_widget_4x_yellow.png.flat
new file mode 100644
index 0000000..f14af5f
Binary files /dev/null and b/src/src/app/build/intermediates/res/merged/debug/drawable-hdpi_widget_4x_yellow.png.flat differ
diff --git a/src/src/app/build/intermediates/res/merged/debug/drawable_new_note.xml.flat b/src/src/app/build/intermediates/res/merged/debug/drawable_new_note.xml.flat
new file mode 100644
index 0000000..a03b64a
Binary files /dev/null and b/src/src/app/build/intermediates/res/merged/debug/drawable_new_note.xml.flat differ
diff --git a/src/src/app/build/intermediates/res/merged/debug/layout_account_dialog_title.xml.flat b/src/src/app/build/intermediates/res/merged/debug/layout_account_dialog_title.xml.flat
new file mode 100644
index 0000000..4d526c5
Binary files /dev/null and b/src/src/app/build/intermediates/res/merged/debug/layout_account_dialog_title.xml.flat differ
diff --git a/src/src/app/build/intermediates/res/merged/debug/layout_add_account_text.xml.flat b/src/src/app/build/intermediates/res/merged/debug/layout_add_account_text.xml.flat
new file mode 100644
index 0000000..dfdb276
Binary files /dev/null and b/src/src/app/build/intermediates/res/merged/debug/layout_add_account_text.xml.flat differ
diff --git a/src/src/app/build/intermediates/res/merged/debug/layout_datetime_picker.xml.flat b/src/src/app/build/intermediates/res/merged/debug/layout_datetime_picker.xml.flat
new file mode 100644
index 0000000..83b2ed5
Binary files /dev/null and b/src/src/app/build/intermediates/res/merged/debug/layout_datetime_picker.xml.flat differ
diff --git a/src/src/app/build/intermediates/res/merged/debug/layout_dialog_edit_text.xml.flat b/src/src/app/build/intermediates/res/merged/debug/layout_dialog_edit_text.xml.flat
new file mode 100644
index 0000000..f4d7baa
Binary files /dev/null and b/src/src/app/build/intermediates/res/merged/debug/layout_dialog_edit_text.xml.flat differ
diff --git a/src/src/app/build/intermediates/res/merged/debug/layout_dialog_pwd.xml.flat b/src/src/app/build/intermediates/res/merged/debug/layout_dialog_pwd.xml.flat
new file mode 100644
index 0000000..1eb91ff
Binary files /dev/null and b/src/src/app/build/intermediates/res/merged/debug/layout_dialog_pwd.xml.flat differ
diff --git a/src/src/app/build/intermediates/res/merged/debug/layout_dialog_pwd_confirm.xml.flat b/src/src/app/build/intermediates/res/merged/debug/layout_dialog_pwd_confirm.xml.flat
new file mode 100644
index 0000000..e2419a9
Binary files /dev/null and b/src/src/app/build/intermediates/res/merged/debug/layout_dialog_pwd_confirm.xml.flat differ
diff --git a/src/src/app/build/intermediates/res/merged/debug/layout_dialog_save.xml.flat b/src/src/app/build/intermediates/res/merged/debug/layout_dialog_save.xml.flat
new file mode 100644
index 0000000..847c14f
Binary files /dev/null and b/src/src/app/build/intermediates/res/merged/debug/layout_dialog_save.xml.flat differ
diff --git a/src/src/app/build/intermediates/res/merged/debug/layout_folder_list_item.xml.flat b/src/src/app/build/intermediates/res/merged/debug/layout_folder_list_item.xml.flat
new file mode 100644
index 0000000..9a0c568
Binary files /dev/null and b/src/src/app/build/intermediates/res/merged/debug/layout_folder_list_item.xml.flat differ
diff --git a/src/src/app/build/intermediates/res/merged/debug/layout_gesture_setting.xml.flat b/src/src/app/build/intermediates/res/merged/debug/layout_gesture_setting.xml.flat
new file mode 100644
index 0000000..46284f1
Binary files /dev/null and b/src/src/app/build/intermediates/res/merged/debug/layout_gesture_setting.xml.flat differ
diff --git a/src/src/app/build/intermediates/res/merged/debug/layout_myboard.xml.flat b/src/src/app/build/intermediates/res/merged/debug/layout_myboard.xml.flat
new file mode 100644
index 0000000..87663c8
Binary files /dev/null and b/src/src/app/build/intermediates/res/merged/debug/layout_myboard.xml.flat differ
diff --git a/src/src/app/build/intermediates/res/merged/debug/layout_note_edit.xml.flat b/src/src/app/build/intermediates/res/merged/debug/layout_note_edit.xml.flat
new file mode 100644
index 0000000..021461d
Binary files /dev/null and b/src/src/app/build/intermediates/res/merged/debug/layout_note_edit.xml.flat differ
diff --git a/src/src/app/build/intermediates/res/merged/debug/layout_note_edit_list_item.xml.flat b/src/src/app/build/intermediates/res/merged/debug/layout_note_edit_list_item.xml.flat
new file mode 100644
index 0000000..9648c16
Binary files /dev/null and b/src/src/app/build/intermediates/res/merged/debug/layout_note_edit_list_item.xml.flat differ
diff --git a/src/src/app/build/intermediates/res/merged/debug/layout_note_item.xml.flat b/src/src/app/build/intermediates/res/merged/debug/layout_note_item.xml.flat
new file mode 100644
index 0000000..ebec76f
Binary files /dev/null and b/src/src/app/build/intermediates/res/merged/debug/layout_note_item.xml.flat differ
diff --git a/src/src/app/build/intermediates/res/merged/debug/layout_note_list.xml.flat b/src/src/app/build/intermediates/res/merged/debug/layout_note_list.xml.flat
new file mode 100644
index 0000000..ad2e7a6
Binary files /dev/null and b/src/src/app/build/intermediates/res/merged/debug/layout_note_list.xml.flat differ
diff --git a/src/src/app/build/intermediates/res/merged/debug/layout_note_list_dropdown_menu.xml.flat b/src/src/app/build/intermediates/res/merged/debug/layout_note_list_dropdown_menu.xml.flat
new file mode 100644
index 0000000..81f3247
Binary files /dev/null and b/src/src/app/build/intermediates/res/merged/debug/layout_note_list_dropdown_menu.xml.flat differ
diff --git a/src/src/app/build/intermediates/res/merged/debug/layout_note_list_footer.xml.flat b/src/src/app/build/intermediates/res/merged/debug/layout_note_list_footer.xml.flat
new file mode 100644
index 0000000..39289bf
Binary files /dev/null and b/src/src/app/build/intermediates/res/merged/debug/layout_note_list_footer.xml.flat differ
diff --git a/src/src/app/build/intermediates/res/merged/debug/layout_settings_header.xml.flat b/src/src/app/build/intermediates/res/merged/debug/layout_settings_header.xml.flat
new file mode 100644
index 0000000..7d363b0
Binary files /dev/null and b/src/src/app/build/intermediates/res/merged/debug/layout_settings_header.xml.flat differ
diff --git a/src/src/app/build/intermediates/res/merged/debug/layout_widget_2x.xml.flat b/src/src/app/build/intermediates/res/merged/debug/layout_widget_2x.xml.flat
new file mode 100644
index 0000000..0ce6159
Binary files /dev/null and b/src/src/app/build/intermediates/res/merged/debug/layout_widget_2x.xml.flat differ
diff --git a/src/src/app/build/intermediates/res/merged/debug/layout_widget_4x.xml.flat b/src/src/app/build/intermediates/res/merged/debug/layout_widget_4x.xml.flat
new file mode 100644
index 0000000..8f2159f
Binary files /dev/null and b/src/src/app/build/intermediates/res/merged/debug/layout_widget_4x.xml.flat differ
diff --git a/src/src/app/build/intermediates/res/merged/debug/menu_call_note_edit.xml.flat b/src/src/app/build/intermediates/res/merged/debug/menu_call_note_edit.xml.flat
new file mode 100644
index 0000000..da841e0
Binary files /dev/null and b/src/src/app/build/intermediates/res/merged/debug/menu_call_note_edit.xml.flat differ
diff --git a/src/src/app/build/intermediates/res/merged/debug/menu_call_record_folder.xml.flat b/src/src/app/build/intermediates/res/merged/debug/menu_call_record_folder.xml.flat
new file mode 100644
index 0000000..554b10d
Binary files /dev/null and b/src/src/app/build/intermediates/res/merged/debug/menu_call_record_folder.xml.flat differ
diff --git a/src/src/app/build/intermediates/res/merged/debug/menu_note_edit.xml.flat b/src/src/app/build/intermediates/res/merged/debug/menu_note_edit.xml.flat
new file mode 100644
index 0000000..1eacdd5
Binary files /dev/null and b/src/src/app/build/intermediates/res/merged/debug/menu_note_edit.xml.flat differ
diff --git a/src/src/app/build/intermediates/res/merged/debug/menu_note_list.xml.flat b/src/src/app/build/intermediates/res/merged/debug/menu_note_list.xml.flat
new file mode 100644
index 0000000..43fe3b8
Binary files /dev/null and b/src/src/app/build/intermediates/res/merged/debug/menu_note_list.xml.flat differ
diff --git a/src/src/app/build/intermediates/res/merged/debug/menu_note_list_dropdown.xml.flat b/src/src/app/build/intermediates/res/merged/debug/menu_note_list_dropdown.xml.flat
new file mode 100644
index 0000000..6430c1a
Binary files /dev/null and b/src/src/app/build/intermediates/res/merged/debug/menu_note_list_dropdown.xml.flat differ
diff --git a/src/src/app/build/intermediates/res/merged/debug/menu_note_list_options.xml.flat b/src/src/app/build/intermediates/res/merged/debug/menu_note_list_options.xml.flat
new file mode 100644
index 0000000..60af85a
Binary files /dev/null and b/src/src/app/build/intermediates/res/merged/debug/menu_note_list_options.xml.flat differ
diff --git a/src/src/app/build/intermediates/res/merged/debug/menu_sub_folder.xml.flat b/src/src/app/build/intermediates/res/merged/debug/menu_sub_folder.xml.flat
new file mode 100644
index 0000000..f4c94d7
Binary files /dev/null and b/src/src/app/build/intermediates/res/merged/debug/menu_sub_folder.xml.flat differ
diff --git a/src/src/app/build/intermediates/res/merged/debug/raw-zh-rCN_contact.txt.flat b/src/src/app/build/intermediates/res/merged/debug/raw-zh-rCN_contact.txt.flat
new file mode 100644
index 0000000..c356187
Binary files /dev/null and b/src/src/app/build/intermediates/res/merged/debug/raw-zh-rCN_contact.txt.flat differ
diff --git a/src/src/app/build/intermediates/res/merged/debug/raw-zh-rCN_event.txt.flat b/src/src/app/build/intermediates/res/merged/debug/raw-zh-rCN_event.txt.flat
new file mode 100644
index 0000000..45af1c6
Binary files /dev/null and b/src/src/app/build/intermediates/res/merged/debug/raw-zh-rCN_event.txt.flat differ
diff --git a/src/src/app/build/intermediates/res/merged/debug/raw-zh-rCN_gestures.txt.flat b/src/src/app/build/intermediates/res/merged/debug/raw-zh-rCN_gestures.txt.flat
new file mode 100644
index 0000000..08b91f9
Binary files /dev/null and b/src/src/app/build/intermediates/res/merged/debug/raw-zh-rCN_gestures.txt.flat differ
diff --git a/src/src/app/build/intermediates/res/merged/debug/raw-zh-rCN_introduction.flat b/src/src/app/build/intermediates/res/merged/debug/raw-zh-rCN_introduction.flat
new file mode 100644
index 0000000..e189a02
Binary files /dev/null and b/src/src/app/build/intermediates/res/merged/debug/raw-zh-rCN_introduction.flat differ
diff --git a/src/src/app/build/intermediates/res/merged/debug/raw-zh-rCN_passwd.txt.flat b/src/src/app/build/intermediates/res/merged/debug/raw-zh-rCN_passwd.txt.flat
new file mode 100644
index 0000000..325d476
Binary files /dev/null and b/src/src/app/build/intermediates/res/merged/debug/raw-zh-rCN_passwd.txt.flat differ
diff --git a/src/src/app/build/intermediates/res/merged/debug/raw_contact.txt.flat b/src/src/app/build/intermediates/res/merged/debug/raw_contact.txt.flat
new file mode 100644
index 0000000..0c1bd4f
Binary files /dev/null and b/src/src/app/build/intermediates/res/merged/debug/raw_contact.txt.flat differ
diff --git a/src/src/app/build/intermediates/res/merged/debug/raw_event.txt.flat b/src/src/app/build/intermediates/res/merged/debug/raw_event.txt.flat
new file mode 100644
index 0000000..ab8bef5
Binary files /dev/null and b/src/src/app/build/intermediates/res/merged/debug/raw_event.txt.flat differ
diff --git a/src/src/app/build/intermediates/res/merged/debug/raw_gestures.txt.flat b/src/src/app/build/intermediates/res/merged/debug/raw_gestures.txt.flat
new file mode 100644
index 0000000..a04ac2f
Binary files /dev/null and b/src/src/app/build/intermediates/res/merged/debug/raw_gestures.txt.flat differ
diff --git a/src/src/app/build/intermediates/res/merged/debug/raw_introduction.flat b/src/src/app/build/intermediates/res/merged/debug/raw_introduction.flat
new file mode 100644
index 0000000..4b88626
Binary files /dev/null and b/src/src/app/build/intermediates/res/merged/debug/raw_introduction.flat differ
diff --git a/src/src/app/build/intermediates/res/merged/debug/raw_passwd.txt.flat b/src/src/app/build/intermediates/res/merged/debug/raw_passwd.txt.flat
new file mode 100644
index 0000000..dd49a12
Binary files /dev/null and b/src/src/app/build/intermediates/res/merged/debug/raw_passwd.txt.flat differ
diff --git a/src/src/app/build/intermediates/res/merged/debug/values-af_values-af.arsc.flat b/src/src/app/build/intermediates/res/merged/debug/values-af_values-af.arsc.flat
new file mode 100644
index 0000000..31e738e
Binary files /dev/null and b/src/src/app/build/intermediates/res/merged/debug/values-af_values-af.arsc.flat differ
diff --git a/src/src/app/build/intermediates/res/merged/debug/values-am_values-am.arsc.flat b/src/src/app/build/intermediates/res/merged/debug/values-am_values-am.arsc.flat
new file mode 100644
index 0000000..b205961
Binary files /dev/null and b/src/src/app/build/intermediates/res/merged/debug/values-am_values-am.arsc.flat differ
diff --git a/src/src/app/build/intermediates/res/merged/debug/values-ar_values-ar.arsc.flat b/src/src/app/build/intermediates/res/merged/debug/values-ar_values-ar.arsc.flat
new file mode 100644
index 0000000..d0f3c4f
Binary files /dev/null and b/src/src/app/build/intermediates/res/merged/debug/values-ar_values-ar.arsc.flat differ
diff --git a/src/src/app/build/intermediates/res/merged/debug/values-as_values-as.arsc.flat b/src/src/app/build/intermediates/res/merged/debug/values-as_values-as.arsc.flat
new file mode 100644
index 0000000..cdae338
Binary files /dev/null and b/src/src/app/build/intermediates/res/merged/debug/values-as_values-as.arsc.flat differ
diff --git a/src/src/app/build/intermediates/res/merged/debug/values-az_values-az.arsc.flat b/src/src/app/build/intermediates/res/merged/debug/values-az_values-az.arsc.flat
new file mode 100644
index 0000000..7eefb3f
Binary files /dev/null and b/src/src/app/build/intermediates/res/merged/debug/values-az_values-az.arsc.flat differ
diff --git a/src/src/app/build/intermediates/res/merged/debug/values-b+sr+Latn_values-b+sr+Latn.arsc.flat b/src/src/app/build/intermediates/res/merged/debug/values-b+sr+Latn_values-b+sr+Latn.arsc.flat
new file mode 100644
index 0000000..9c26634
Binary files /dev/null and b/src/src/app/build/intermediates/res/merged/debug/values-b+sr+Latn_values-b+sr+Latn.arsc.flat differ
diff --git a/src/src/app/build/intermediates/res/merged/debug/values-be_values-be.arsc.flat b/src/src/app/build/intermediates/res/merged/debug/values-be_values-be.arsc.flat
new file mode 100644
index 0000000..e2a6bef
Binary files /dev/null and b/src/src/app/build/intermediates/res/merged/debug/values-be_values-be.arsc.flat differ
diff --git a/src/src/app/build/intermediates/res/merged/debug/values-bg_values-bg.arsc.flat b/src/src/app/build/intermediates/res/merged/debug/values-bg_values-bg.arsc.flat
new file mode 100644
index 0000000..5e8d994
Binary files /dev/null and b/src/src/app/build/intermediates/res/merged/debug/values-bg_values-bg.arsc.flat differ
diff --git a/src/src/app/build/intermediates/res/merged/debug/values-bn_values-bn.arsc.flat b/src/src/app/build/intermediates/res/merged/debug/values-bn_values-bn.arsc.flat
new file mode 100644
index 0000000..5bed02f
Binary files /dev/null and b/src/src/app/build/intermediates/res/merged/debug/values-bn_values-bn.arsc.flat differ
diff --git a/src/src/app/build/intermediates/res/merged/debug/values-bs_values-bs.arsc.flat b/src/src/app/build/intermediates/res/merged/debug/values-bs_values-bs.arsc.flat
new file mode 100644
index 0000000..7d756b2
Binary files /dev/null and b/src/src/app/build/intermediates/res/merged/debug/values-bs_values-bs.arsc.flat differ
diff --git a/src/src/app/build/intermediates/res/merged/debug/values-ca_values-ca.arsc.flat b/src/src/app/build/intermediates/res/merged/debug/values-ca_values-ca.arsc.flat
new file mode 100644
index 0000000..b09809c
Binary files /dev/null and b/src/src/app/build/intermediates/res/merged/debug/values-ca_values-ca.arsc.flat differ
diff --git a/src/src/app/build/intermediates/res/merged/debug/values-cs_values-cs.arsc.flat b/src/src/app/build/intermediates/res/merged/debug/values-cs_values-cs.arsc.flat
new file mode 100644
index 0000000..0e2d545
Binary files /dev/null and b/src/src/app/build/intermediates/res/merged/debug/values-cs_values-cs.arsc.flat differ
diff --git a/src/src/app/build/intermediates/res/merged/debug/values-da_values-da.arsc.flat b/src/src/app/build/intermediates/res/merged/debug/values-da_values-da.arsc.flat
new file mode 100644
index 0000000..745f10f
Binary files /dev/null and b/src/src/app/build/intermediates/res/merged/debug/values-da_values-da.arsc.flat differ
diff --git a/src/src/app/build/intermediates/res/merged/debug/values-de_values-de.arsc.flat b/src/src/app/build/intermediates/res/merged/debug/values-de_values-de.arsc.flat
new file mode 100644
index 0000000..fb399e0
Binary files /dev/null and b/src/src/app/build/intermediates/res/merged/debug/values-de_values-de.arsc.flat differ
diff --git a/src/src/app/build/intermediates/res/merged/debug/values-el_values-el.arsc.flat b/src/src/app/build/intermediates/res/merged/debug/values-el_values-el.arsc.flat
new file mode 100644
index 0000000..3f2d585
Binary files /dev/null and b/src/src/app/build/intermediates/res/merged/debug/values-el_values-el.arsc.flat differ
diff --git a/src/src/app/build/intermediates/res/merged/debug/values-en-rAU_values-en-rAU.arsc.flat b/src/src/app/build/intermediates/res/merged/debug/values-en-rAU_values-en-rAU.arsc.flat
new file mode 100644
index 0000000..2c7e4f1
Binary files /dev/null and b/src/src/app/build/intermediates/res/merged/debug/values-en-rAU_values-en-rAU.arsc.flat differ
diff --git a/src/src/app/build/intermediates/res/merged/debug/values-en-rCA_values-en-rCA.arsc.flat b/src/src/app/build/intermediates/res/merged/debug/values-en-rCA_values-en-rCA.arsc.flat
new file mode 100644
index 0000000..c3f6fc1
Binary files /dev/null and b/src/src/app/build/intermediates/res/merged/debug/values-en-rCA_values-en-rCA.arsc.flat differ
diff --git a/src/src/app/build/intermediates/res/merged/debug/values-en-rGB_values-en-rGB.arsc.flat b/src/src/app/build/intermediates/res/merged/debug/values-en-rGB_values-en-rGB.arsc.flat
new file mode 100644
index 0000000..bac1852
Binary files /dev/null and b/src/src/app/build/intermediates/res/merged/debug/values-en-rGB_values-en-rGB.arsc.flat differ
diff --git a/src/src/app/build/intermediates/res/merged/debug/values-en-rIN_values-en-rIN.arsc.flat b/src/src/app/build/intermediates/res/merged/debug/values-en-rIN_values-en-rIN.arsc.flat
new file mode 100644
index 0000000..6e1f152
Binary files /dev/null and b/src/src/app/build/intermediates/res/merged/debug/values-en-rIN_values-en-rIN.arsc.flat differ
diff --git a/src/src/app/build/intermediates/res/merged/debug/values-en-rXC_values-en-rXC.arsc.flat b/src/src/app/build/intermediates/res/merged/debug/values-en-rXC_values-en-rXC.arsc.flat
new file mode 100644
index 0000000..46bd187
Binary files /dev/null and b/src/src/app/build/intermediates/res/merged/debug/values-en-rXC_values-en-rXC.arsc.flat differ
diff --git a/src/src/app/build/intermediates/res/merged/debug/values-es-rUS_values-es-rUS.arsc.flat b/src/src/app/build/intermediates/res/merged/debug/values-es-rUS_values-es-rUS.arsc.flat
new file mode 100644
index 0000000..902c398
Binary files /dev/null and b/src/src/app/build/intermediates/res/merged/debug/values-es-rUS_values-es-rUS.arsc.flat differ
diff --git a/src/src/app/build/intermediates/res/merged/debug/values-es_values-es.arsc.flat b/src/src/app/build/intermediates/res/merged/debug/values-es_values-es.arsc.flat
new file mode 100644
index 0000000..e7b5354
Binary files /dev/null and b/src/src/app/build/intermediates/res/merged/debug/values-es_values-es.arsc.flat differ
diff --git a/src/src/app/build/intermediates/res/merged/debug/values-et_values-et.arsc.flat b/src/src/app/build/intermediates/res/merged/debug/values-et_values-et.arsc.flat
new file mode 100644
index 0000000..149d5e8
Binary files /dev/null and b/src/src/app/build/intermediates/res/merged/debug/values-et_values-et.arsc.flat differ
diff --git a/src/src/app/build/intermediates/res/merged/debug/values-eu_values-eu.arsc.flat b/src/src/app/build/intermediates/res/merged/debug/values-eu_values-eu.arsc.flat
new file mode 100644
index 0000000..ea3d0ad
Binary files /dev/null and b/src/src/app/build/intermediates/res/merged/debug/values-eu_values-eu.arsc.flat differ
diff --git a/src/src/app/build/intermediates/res/merged/debug/values-fa_values-fa.arsc.flat b/src/src/app/build/intermediates/res/merged/debug/values-fa_values-fa.arsc.flat
new file mode 100644
index 0000000..2dbb137
Binary files /dev/null and b/src/src/app/build/intermediates/res/merged/debug/values-fa_values-fa.arsc.flat differ
diff --git a/src/src/app/build/intermediates/res/merged/debug/values-fi_values-fi.arsc.flat b/src/src/app/build/intermediates/res/merged/debug/values-fi_values-fi.arsc.flat
new file mode 100644
index 0000000..69d3fec
Binary files /dev/null and b/src/src/app/build/intermediates/res/merged/debug/values-fi_values-fi.arsc.flat differ
diff --git a/src/src/app/build/intermediates/res/merged/debug/values-fr-rCA_values-fr-rCA.arsc.flat b/src/src/app/build/intermediates/res/merged/debug/values-fr-rCA_values-fr-rCA.arsc.flat
new file mode 100644
index 0000000..3cc8520
Binary files /dev/null and b/src/src/app/build/intermediates/res/merged/debug/values-fr-rCA_values-fr-rCA.arsc.flat differ
diff --git a/src/src/app/build/intermediates/res/merged/debug/values-fr_values-fr.arsc.flat b/src/src/app/build/intermediates/res/merged/debug/values-fr_values-fr.arsc.flat
new file mode 100644
index 0000000..e5a9a35
Binary files /dev/null and b/src/src/app/build/intermediates/res/merged/debug/values-fr_values-fr.arsc.flat differ
diff --git a/src/src/app/build/intermediates/res/merged/debug/values-gl_values-gl.arsc.flat b/src/src/app/build/intermediates/res/merged/debug/values-gl_values-gl.arsc.flat
new file mode 100644
index 0000000..5fcd4a4
Binary files /dev/null and b/src/src/app/build/intermediates/res/merged/debug/values-gl_values-gl.arsc.flat differ
diff --git a/src/src/app/build/intermediates/res/merged/debug/values-gu_values-gu.arsc.flat b/src/src/app/build/intermediates/res/merged/debug/values-gu_values-gu.arsc.flat
new file mode 100644
index 0000000..8da0b61
Binary files /dev/null and b/src/src/app/build/intermediates/res/merged/debug/values-gu_values-gu.arsc.flat differ
diff --git a/src/src/app/build/intermediates/res/merged/debug/values-h720dp-v13_values-h720dp-v13.arsc.flat b/src/src/app/build/intermediates/res/merged/debug/values-h720dp-v13_values-h720dp-v13.arsc.flat
new file mode 100644
index 0000000..a84fda4
Binary files /dev/null and b/src/src/app/build/intermediates/res/merged/debug/values-h720dp-v13_values-h720dp-v13.arsc.flat differ
diff --git a/src/src/app/build/intermediates/res/merged/debug/values-hdpi-v4_values-hdpi-v4.arsc.flat b/src/src/app/build/intermediates/res/merged/debug/values-hdpi-v4_values-hdpi-v4.arsc.flat
new file mode 100644
index 0000000..715b341
Binary files /dev/null and b/src/src/app/build/intermediates/res/merged/debug/values-hdpi-v4_values-hdpi-v4.arsc.flat differ
diff --git a/src/src/app/build/intermediates/res/merged/debug/values-hi_values-hi.arsc.flat b/src/src/app/build/intermediates/res/merged/debug/values-hi_values-hi.arsc.flat
new file mode 100644
index 0000000..3df9f32
Binary files /dev/null and b/src/src/app/build/intermediates/res/merged/debug/values-hi_values-hi.arsc.flat differ
diff --git a/src/src/app/build/intermediates/res/merged/debug/values-hr_values-hr.arsc.flat b/src/src/app/build/intermediates/res/merged/debug/values-hr_values-hr.arsc.flat
new file mode 100644
index 0000000..5c3e980
Binary files /dev/null and b/src/src/app/build/intermediates/res/merged/debug/values-hr_values-hr.arsc.flat differ
diff --git a/src/src/app/build/intermediates/res/merged/debug/values-hu_values-hu.arsc.flat b/src/src/app/build/intermediates/res/merged/debug/values-hu_values-hu.arsc.flat
new file mode 100644
index 0000000..eb89f41
Binary files /dev/null and b/src/src/app/build/intermediates/res/merged/debug/values-hu_values-hu.arsc.flat differ
diff --git a/src/src/app/build/intermediates/res/merged/debug/values-hy_values-hy.arsc.flat b/src/src/app/build/intermediates/res/merged/debug/values-hy_values-hy.arsc.flat
new file mode 100644
index 0000000..e7a9e9a
Binary files /dev/null and b/src/src/app/build/intermediates/res/merged/debug/values-hy_values-hy.arsc.flat differ
diff --git a/src/src/app/build/intermediates/res/merged/debug/values-in_values-in.arsc.flat b/src/src/app/build/intermediates/res/merged/debug/values-in_values-in.arsc.flat
new file mode 100644
index 0000000..21ebebd
Binary files /dev/null and b/src/src/app/build/intermediates/res/merged/debug/values-in_values-in.arsc.flat differ
diff --git a/src/src/app/build/intermediates/res/merged/debug/values-is_values-is.arsc.flat b/src/src/app/build/intermediates/res/merged/debug/values-is_values-is.arsc.flat
new file mode 100644
index 0000000..cce1033
Binary files /dev/null and b/src/src/app/build/intermediates/res/merged/debug/values-is_values-is.arsc.flat differ
diff --git a/src/src/app/build/intermediates/res/merged/debug/values-it_values-it.arsc.flat b/src/src/app/build/intermediates/res/merged/debug/values-it_values-it.arsc.flat
new file mode 100644
index 0000000..d95a5ea
Binary files /dev/null and b/src/src/app/build/intermediates/res/merged/debug/values-it_values-it.arsc.flat differ
diff --git a/src/src/app/build/intermediates/res/merged/debug/values-iw_values-iw.arsc.flat b/src/src/app/build/intermediates/res/merged/debug/values-iw_values-iw.arsc.flat
new file mode 100644
index 0000000..3f6c06b
Binary files /dev/null and b/src/src/app/build/intermediates/res/merged/debug/values-iw_values-iw.arsc.flat differ
diff --git a/src/src/app/build/intermediates/res/merged/debug/values-ja_values-ja.arsc.flat b/src/src/app/build/intermediates/res/merged/debug/values-ja_values-ja.arsc.flat
new file mode 100644
index 0000000..0fd1e69
Binary files /dev/null and b/src/src/app/build/intermediates/res/merged/debug/values-ja_values-ja.arsc.flat differ
diff --git a/src/src/app/build/intermediates/res/merged/debug/values-ka_values-ka.arsc.flat b/src/src/app/build/intermediates/res/merged/debug/values-ka_values-ka.arsc.flat
new file mode 100644
index 0000000..6bec71c
Binary files /dev/null and b/src/src/app/build/intermediates/res/merged/debug/values-ka_values-ka.arsc.flat differ
diff --git a/src/src/app/build/intermediates/res/merged/debug/values-kk_values-kk.arsc.flat b/src/src/app/build/intermediates/res/merged/debug/values-kk_values-kk.arsc.flat
new file mode 100644
index 0000000..748c3c8
Binary files /dev/null and b/src/src/app/build/intermediates/res/merged/debug/values-kk_values-kk.arsc.flat differ
diff --git a/src/src/app/build/intermediates/res/merged/debug/values-km_values-km.arsc.flat b/src/src/app/build/intermediates/res/merged/debug/values-km_values-km.arsc.flat
new file mode 100644
index 0000000..260579a
Binary files /dev/null and b/src/src/app/build/intermediates/res/merged/debug/values-km_values-km.arsc.flat differ
diff --git a/src/src/app/build/intermediates/res/merged/debug/values-kn_values-kn.arsc.flat b/src/src/app/build/intermediates/res/merged/debug/values-kn_values-kn.arsc.flat
new file mode 100644
index 0000000..b8c4e6d
Binary files /dev/null and b/src/src/app/build/intermediates/res/merged/debug/values-kn_values-kn.arsc.flat differ
diff --git a/src/src/app/build/intermediates/res/merged/debug/values-ko_values-ko.arsc.flat b/src/src/app/build/intermediates/res/merged/debug/values-ko_values-ko.arsc.flat
new file mode 100644
index 0000000..d9f08f5
Binary files /dev/null and b/src/src/app/build/intermediates/res/merged/debug/values-ko_values-ko.arsc.flat differ
diff --git a/src/src/app/build/intermediates/res/merged/debug/values-ky_values-ky.arsc.flat b/src/src/app/build/intermediates/res/merged/debug/values-ky_values-ky.arsc.flat
new file mode 100644
index 0000000..cecb44e
Binary files /dev/null and b/src/src/app/build/intermediates/res/merged/debug/values-ky_values-ky.arsc.flat differ
diff --git a/src/src/app/build/intermediates/res/merged/debug/values-land_values-land.arsc.flat b/src/src/app/build/intermediates/res/merged/debug/values-land_values-land.arsc.flat
new file mode 100644
index 0000000..b06f98d
Binary files /dev/null and b/src/src/app/build/intermediates/res/merged/debug/values-land_values-land.arsc.flat differ
diff --git a/src/src/app/build/intermediates/res/merged/debug/values-large-v4_values-large-v4.arsc.flat b/src/src/app/build/intermediates/res/merged/debug/values-large-v4_values-large-v4.arsc.flat
new file mode 100644
index 0000000..c21ea93
Binary files /dev/null and b/src/src/app/build/intermediates/res/merged/debug/values-large-v4_values-large-v4.arsc.flat differ
diff --git a/src/src/app/build/intermediates/res/merged/debug/values-ldltr-v21_values-ldltr-v21.arsc.flat b/src/src/app/build/intermediates/res/merged/debug/values-ldltr-v21_values-ldltr-v21.arsc.flat
new file mode 100644
index 0000000..c0ec748
Binary files /dev/null and b/src/src/app/build/intermediates/res/merged/debug/values-ldltr-v21_values-ldltr-v21.arsc.flat differ
diff --git a/src/src/app/build/intermediates/res/merged/debug/values-lo_values-lo.arsc.flat b/src/src/app/build/intermediates/res/merged/debug/values-lo_values-lo.arsc.flat
new file mode 100644
index 0000000..79bfd06
Binary files /dev/null and b/src/src/app/build/intermediates/res/merged/debug/values-lo_values-lo.arsc.flat differ
diff --git a/src/src/app/build/intermediates/res/merged/debug/values-lt_values-lt.arsc.flat b/src/src/app/build/intermediates/res/merged/debug/values-lt_values-lt.arsc.flat
new file mode 100644
index 0000000..1b5f5d0
Binary files /dev/null and b/src/src/app/build/intermediates/res/merged/debug/values-lt_values-lt.arsc.flat differ
diff --git a/src/src/app/build/intermediates/res/merged/debug/values-lv_values-lv.arsc.flat b/src/src/app/build/intermediates/res/merged/debug/values-lv_values-lv.arsc.flat
new file mode 100644
index 0000000..c6165a1
Binary files /dev/null and b/src/src/app/build/intermediates/res/merged/debug/values-lv_values-lv.arsc.flat differ
diff --git a/src/src/app/build/intermediates/res/merged/debug/values-mk_values-mk.arsc.flat b/src/src/app/build/intermediates/res/merged/debug/values-mk_values-mk.arsc.flat
new file mode 100644
index 0000000..0badca3
Binary files /dev/null and b/src/src/app/build/intermediates/res/merged/debug/values-mk_values-mk.arsc.flat differ
diff --git a/src/src/app/build/intermediates/res/merged/debug/values-ml_values-ml.arsc.flat b/src/src/app/build/intermediates/res/merged/debug/values-ml_values-ml.arsc.flat
new file mode 100644
index 0000000..f4b6613
Binary files /dev/null and b/src/src/app/build/intermediates/res/merged/debug/values-ml_values-ml.arsc.flat differ
diff --git a/src/src/app/build/intermediates/res/merged/debug/values-mn_values-mn.arsc.flat b/src/src/app/build/intermediates/res/merged/debug/values-mn_values-mn.arsc.flat
new file mode 100644
index 0000000..4c600f0
Binary files /dev/null and b/src/src/app/build/intermediates/res/merged/debug/values-mn_values-mn.arsc.flat differ
diff --git a/src/src/app/build/intermediates/res/merged/debug/values-mr_values-mr.arsc.flat b/src/src/app/build/intermediates/res/merged/debug/values-mr_values-mr.arsc.flat
new file mode 100644
index 0000000..843be17
Binary files /dev/null and b/src/src/app/build/intermediates/res/merged/debug/values-mr_values-mr.arsc.flat differ
diff --git a/src/src/app/build/intermediates/res/merged/debug/values-ms_values-ms.arsc.flat b/src/src/app/build/intermediates/res/merged/debug/values-ms_values-ms.arsc.flat
new file mode 100644
index 0000000..638002f
Binary files /dev/null and b/src/src/app/build/intermediates/res/merged/debug/values-ms_values-ms.arsc.flat differ
diff --git a/src/src/app/build/intermediates/res/merged/debug/values-my_values-my.arsc.flat b/src/src/app/build/intermediates/res/merged/debug/values-my_values-my.arsc.flat
new file mode 100644
index 0000000..e476d27
Binary files /dev/null and b/src/src/app/build/intermediates/res/merged/debug/values-my_values-my.arsc.flat differ
diff --git a/src/src/app/build/intermediates/res/merged/debug/values-nb_values-nb.arsc.flat b/src/src/app/build/intermediates/res/merged/debug/values-nb_values-nb.arsc.flat
new file mode 100644
index 0000000..e5f7e37
Binary files /dev/null and b/src/src/app/build/intermediates/res/merged/debug/values-nb_values-nb.arsc.flat differ
diff --git a/src/src/app/build/intermediates/res/merged/debug/values-ne_values-ne.arsc.flat b/src/src/app/build/intermediates/res/merged/debug/values-ne_values-ne.arsc.flat
new file mode 100644
index 0000000..25b1e98
Binary files /dev/null and b/src/src/app/build/intermediates/res/merged/debug/values-ne_values-ne.arsc.flat differ
diff --git a/src/src/app/build/intermediates/res/merged/debug/values-night-v8_values-night-v8.arsc.flat b/src/src/app/build/intermediates/res/merged/debug/values-night-v8_values-night-v8.arsc.flat
new file mode 100644
index 0000000..f36f9ff
Binary files /dev/null and b/src/src/app/build/intermediates/res/merged/debug/values-night-v8_values-night-v8.arsc.flat differ
diff --git a/src/src/app/build/intermediates/res/merged/debug/values-nl_values-nl.arsc.flat b/src/src/app/build/intermediates/res/merged/debug/values-nl_values-nl.arsc.flat
new file mode 100644
index 0000000..067a377
Binary files /dev/null and b/src/src/app/build/intermediates/res/merged/debug/values-nl_values-nl.arsc.flat differ
diff --git a/src/src/app/build/intermediates/res/merged/debug/values-or_values-or.arsc.flat b/src/src/app/build/intermediates/res/merged/debug/values-or_values-or.arsc.flat
new file mode 100644
index 0000000..253d95c
Binary files /dev/null and b/src/src/app/build/intermediates/res/merged/debug/values-or_values-or.arsc.flat differ
diff --git a/src/src/app/build/intermediates/res/merged/debug/values-pa_values-pa.arsc.flat b/src/src/app/build/intermediates/res/merged/debug/values-pa_values-pa.arsc.flat
new file mode 100644
index 0000000..daedb7b
Binary files /dev/null and b/src/src/app/build/intermediates/res/merged/debug/values-pa_values-pa.arsc.flat differ
diff --git a/src/src/app/build/intermediates/res/merged/debug/values-pl_values-pl.arsc.flat b/src/src/app/build/intermediates/res/merged/debug/values-pl_values-pl.arsc.flat
new file mode 100644
index 0000000..d7c3533
Binary files /dev/null and b/src/src/app/build/intermediates/res/merged/debug/values-pl_values-pl.arsc.flat differ
diff --git a/src/src/app/build/intermediates/res/merged/debug/values-port_values-port.arsc.flat b/src/src/app/build/intermediates/res/merged/debug/values-port_values-port.arsc.flat
new file mode 100644
index 0000000..a84fb92
Binary files /dev/null and b/src/src/app/build/intermediates/res/merged/debug/values-port_values-port.arsc.flat differ
diff --git a/src/src/app/build/intermediates/res/merged/debug/values-pt-rBR_values-pt-rBR.arsc.flat b/src/src/app/build/intermediates/res/merged/debug/values-pt-rBR_values-pt-rBR.arsc.flat
new file mode 100644
index 0000000..cb6af8d
Binary files /dev/null and b/src/src/app/build/intermediates/res/merged/debug/values-pt-rBR_values-pt-rBR.arsc.flat differ
diff --git a/src/src/app/build/intermediates/res/merged/debug/values-pt-rPT_values-pt-rPT.arsc.flat b/src/src/app/build/intermediates/res/merged/debug/values-pt-rPT_values-pt-rPT.arsc.flat
new file mode 100644
index 0000000..8885a98
Binary files /dev/null and b/src/src/app/build/intermediates/res/merged/debug/values-pt-rPT_values-pt-rPT.arsc.flat differ
diff --git a/src/src/app/build/intermediates/res/merged/debug/values-pt_values-pt.arsc.flat b/src/src/app/build/intermediates/res/merged/debug/values-pt_values-pt.arsc.flat
new file mode 100644
index 0000000..8d967a0
Binary files /dev/null and b/src/src/app/build/intermediates/res/merged/debug/values-pt_values-pt.arsc.flat differ
diff --git a/src/src/app/build/intermediates/res/merged/debug/values-ro_values-ro.arsc.flat b/src/src/app/build/intermediates/res/merged/debug/values-ro_values-ro.arsc.flat
new file mode 100644
index 0000000..17f1151
Binary files /dev/null and b/src/src/app/build/intermediates/res/merged/debug/values-ro_values-ro.arsc.flat differ
diff --git a/src/src/app/build/intermediates/res/merged/debug/values-ru_values-ru.arsc.flat b/src/src/app/build/intermediates/res/merged/debug/values-ru_values-ru.arsc.flat
new file mode 100644
index 0000000..bab35cc
Binary files /dev/null and b/src/src/app/build/intermediates/res/merged/debug/values-ru_values-ru.arsc.flat differ
diff --git a/src/src/app/build/intermediates/res/merged/debug/values-si_values-si.arsc.flat b/src/src/app/build/intermediates/res/merged/debug/values-si_values-si.arsc.flat
new file mode 100644
index 0000000..9168ccb
Binary files /dev/null and b/src/src/app/build/intermediates/res/merged/debug/values-si_values-si.arsc.flat differ
diff --git a/src/src/app/build/intermediates/res/merged/debug/values-sk_values-sk.arsc.flat b/src/src/app/build/intermediates/res/merged/debug/values-sk_values-sk.arsc.flat
new file mode 100644
index 0000000..139af07
Binary files /dev/null and b/src/src/app/build/intermediates/res/merged/debug/values-sk_values-sk.arsc.flat differ
diff --git a/src/src/app/build/intermediates/res/merged/debug/values-sl_values-sl.arsc.flat b/src/src/app/build/intermediates/res/merged/debug/values-sl_values-sl.arsc.flat
new file mode 100644
index 0000000..e95cf78
Binary files /dev/null and b/src/src/app/build/intermediates/res/merged/debug/values-sl_values-sl.arsc.flat differ
diff --git a/src/src/app/build/intermediates/res/merged/debug/values-sq_values-sq.arsc.flat b/src/src/app/build/intermediates/res/merged/debug/values-sq_values-sq.arsc.flat
new file mode 100644
index 0000000..94474f6
Binary files /dev/null and b/src/src/app/build/intermediates/res/merged/debug/values-sq_values-sq.arsc.flat differ
diff --git a/src/src/app/build/intermediates/res/merged/debug/values-sr_values-sr.arsc.flat b/src/src/app/build/intermediates/res/merged/debug/values-sr_values-sr.arsc.flat
new file mode 100644
index 0000000..587a6d5
Binary files /dev/null and b/src/src/app/build/intermediates/res/merged/debug/values-sr_values-sr.arsc.flat differ
diff --git a/src/src/app/build/intermediates/res/merged/debug/values-sv_values-sv.arsc.flat b/src/src/app/build/intermediates/res/merged/debug/values-sv_values-sv.arsc.flat
new file mode 100644
index 0000000..e6baa76
Binary files /dev/null and b/src/src/app/build/intermediates/res/merged/debug/values-sv_values-sv.arsc.flat differ
diff --git a/src/src/app/build/intermediates/res/merged/debug/values-sw600dp-v13_values-sw600dp-v13.arsc.flat b/src/src/app/build/intermediates/res/merged/debug/values-sw600dp-v13_values-sw600dp-v13.arsc.flat
new file mode 100644
index 0000000..4c9913d
Binary files /dev/null and b/src/src/app/build/intermediates/res/merged/debug/values-sw600dp-v13_values-sw600dp-v13.arsc.flat differ
diff --git a/src/src/app/build/intermediates/res/merged/debug/values-sw_values-sw.arsc.flat b/src/src/app/build/intermediates/res/merged/debug/values-sw_values-sw.arsc.flat
new file mode 100644
index 0000000..4c5fef2
Binary files /dev/null and b/src/src/app/build/intermediates/res/merged/debug/values-sw_values-sw.arsc.flat differ
diff --git a/src/src/app/build/intermediates/res/merged/debug/values-ta_values-ta.arsc.flat b/src/src/app/build/intermediates/res/merged/debug/values-ta_values-ta.arsc.flat
new file mode 100644
index 0000000..ff7afed
Binary files /dev/null and b/src/src/app/build/intermediates/res/merged/debug/values-ta_values-ta.arsc.flat differ
diff --git a/src/src/app/build/intermediates/res/merged/debug/values-te_values-te.arsc.flat b/src/src/app/build/intermediates/res/merged/debug/values-te_values-te.arsc.flat
new file mode 100644
index 0000000..fa34623
Binary files /dev/null and b/src/src/app/build/intermediates/res/merged/debug/values-te_values-te.arsc.flat differ
diff --git a/src/src/app/build/intermediates/res/merged/debug/values-th_values-th.arsc.flat b/src/src/app/build/intermediates/res/merged/debug/values-th_values-th.arsc.flat
new file mode 100644
index 0000000..3ed09ae
Binary files /dev/null and b/src/src/app/build/intermediates/res/merged/debug/values-th_values-th.arsc.flat differ
diff --git a/src/src/app/build/intermediates/res/merged/debug/values-tl_values-tl.arsc.flat b/src/src/app/build/intermediates/res/merged/debug/values-tl_values-tl.arsc.flat
new file mode 100644
index 0000000..a4b041e
Binary files /dev/null and b/src/src/app/build/intermediates/res/merged/debug/values-tl_values-tl.arsc.flat differ
diff --git a/src/src/app/build/intermediates/res/merged/debug/values-tr_values-tr.arsc.flat b/src/src/app/build/intermediates/res/merged/debug/values-tr_values-tr.arsc.flat
new file mode 100644
index 0000000..4b3b169
Binary files /dev/null and b/src/src/app/build/intermediates/res/merged/debug/values-tr_values-tr.arsc.flat differ
diff --git a/src/src/app/build/intermediates/res/merged/debug/values-uk_values-uk.arsc.flat b/src/src/app/build/intermediates/res/merged/debug/values-uk_values-uk.arsc.flat
new file mode 100644
index 0000000..4c0e0c7
Binary files /dev/null and b/src/src/app/build/intermediates/res/merged/debug/values-uk_values-uk.arsc.flat differ
diff --git a/src/src/app/build/intermediates/res/merged/debug/values-ur_values-ur.arsc.flat b/src/src/app/build/intermediates/res/merged/debug/values-ur_values-ur.arsc.flat
new file mode 100644
index 0000000..bbfdce9
Binary files /dev/null and b/src/src/app/build/intermediates/res/merged/debug/values-ur_values-ur.arsc.flat differ
diff --git a/src/src/app/build/intermediates/res/merged/debug/values-uz_values-uz.arsc.flat b/src/src/app/build/intermediates/res/merged/debug/values-uz_values-uz.arsc.flat
new file mode 100644
index 0000000..73a105d
Binary files /dev/null and b/src/src/app/build/intermediates/res/merged/debug/values-uz_values-uz.arsc.flat differ
diff --git a/src/src/app/build/intermediates/res/merged/debug/values-v16_values-v16.arsc.flat b/src/src/app/build/intermediates/res/merged/debug/values-v16_values-v16.arsc.flat
new file mode 100644
index 0000000..3171a23
Binary files /dev/null and b/src/src/app/build/intermediates/res/merged/debug/values-v16_values-v16.arsc.flat differ
diff --git a/src/src/app/build/intermediates/res/merged/debug/values-v17_values-v17.arsc.flat b/src/src/app/build/intermediates/res/merged/debug/values-v17_values-v17.arsc.flat
new file mode 100644
index 0000000..cc8661a
Binary files /dev/null and b/src/src/app/build/intermediates/res/merged/debug/values-v17_values-v17.arsc.flat differ
diff --git a/src/src/app/build/intermediates/res/merged/debug/values-v18_values-v18.arsc.flat b/src/src/app/build/intermediates/res/merged/debug/values-v18_values-v18.arsc.flat
new file mode 100644
index 0000000..a0d6535
Binary files /dev/null and b/src/src/app/build/intermediates/res/merged/debug/values-v18_values-v18.arsc.flat differ
diff --git a/src/src/app/build/intermediates/res/merged/debug/values-v21_values-v21.arsc.flat b/src/src/app/build/intermediates/res/merged/debug/values-v21_values-v21.arsc.flat
new file mode 100644
index 0000000..909f283
Binary files /dev/null and b/src/src/app/build/intermediates/res/merged/debug/values-v21_values-v21.arsc.flat differ
diff --git a/src/src/app/build/intermediates/res/merged/debug/values-v22_values-v22.arsc.flat b/src/src/app/build/intermediates/res/merged/debug/values-v22_values-v22.arsc.flat
new file mode 100644
index 0000000..475abda
Binary files /dev/null and b/src/src/app/build/intermediates/res/merged/debug/values-v22_values-v22.arsc.flat differ
diff --git a/src/src/app/build/intermediates/res/merged/debug/values-v23_values-v23.arsc.flat b/src/src/app/build/intermediates/res/merged/debug/values-v23_values-v23.arsc.flat
new file mode 100644
index 0000000..ce741ad
Binary files /dev/null and b/src/src/app/build/intermediates/res/merged/debug/values-v23_values-v23.arsc.flat differ
diff --git a/src/src/app/build/intermediates/res/merged/debug/values-v24_values-v24.arsc.flat b/src/src/app/build/intermediates/res/merged/debug/values-v24_values-v24.arsc.flat
new file mode 100644
index 0000000..6a17454
Binary files /dev/null and b/src/src/app/build/intermediates/res/merged/debug/values-v24_values-v24.arsc.flat differ
diff --git a/src/src/app/build/intermediates/res/merged/debug/values-v25_values-v25.arsc.flat b/src/src/app/build/intermediates/res/merged/debug/values-v25_values-v25.arsc.flat
new file mode 100644
index 0000000..1fb550f
Binary files /dev/null and b/src/src/app/build/intermediates/res/merged/debug/values-v25_values-v25.arsc.flat differ
diff --git a/src/src/app/build/intermediates/res/merged/debug/values-v26_values-v26.arsc.flat b/src/src/app/build/intermediates/res/merged/debug/values-v26_values-v26.arsc.flat
new file mode 100644
index 0000000..46ab6ad
Binary files /dev/null and b/src/src/app/build/intermediates/res/merged/debug/values-v26_values-v26.arsc.flat differ
diff --git a/src/src/app/build/intermediates/res/merged/debug/values-v28_values-v28.arsc.flat b/src/src/app/build/intermediates/res/merged/debug/values-v28_values-v28.arsc.flat
new file mode 100644
index 0000000..272dcad
Binary files /dev/null and b/src/src/app/build/intermediates/res/merged/debug/values-v28_values-v28.arsc.flat differ
diff --git a/src/src/app/build/intermediates/res/merged/debug/values-vi_values-vi.arsc.flat b/src/src/app/build/intermediates/res/merged/debug/values-vi_values-vi.arsc.flat
new file mode 100644
index 0000000..8f9ead6
Binary files /dev/null and b/src/src/app/build/intermediates/res/merged/debug/values-vi_values-vi.arsc.flat differ
diff --git a/src/src/app/build/intermediates/res/merged/debug/values-watch-v20_values-watch-v20.arsc.flat b/src/src/app/build/intermediates/res/merged/debug/values-watch-v20_values-watch-v20.arsc.flat
new file mode 100644
index 0000000..3127412
Binary files /dev/null and b/src/src/app/build/intermediates/res/merged/debug/values-watch-v20_values-watch-v20.arsc.flat differ
diff --git a/src/src/app/build/intermediates/res/merged/debug/values-watch-v21_values-watch-v21.arsc.flat b/src/src/app/build/intermediates/res/merged/debug/values-watch-v21_values-watch-v21.arsc.flat
new file mode 100644
index 0000000..54fdb72
Binary files /dev/null and b/src/src/app/build/intermediates/res/merged/debug/values-watch-v21_values-watch-v21.arsc.flat differ
diff --git a/src/src/app/build/intermediates/res/merged/debug/values-xlarge-v4_values-xlarge-v4.arsc.flat b/src/src/app/build/intermediates/res/merged/debug/values-xlarge-v4_values-xlarge-v4.arsc.flat
new file mode 100644
index 0000000..ed9b1c0
Binary files /dev/null and b/src/src/app/build/intermediates/res/merged/debug/values-xlarge-v4_values-xlarge-v4.arsc.flat differ
diff --git a/src/src/app/build/intermediates/res/merged/debug/values-zh-rCN_values-zh-rCN.arsc.flat b/src/src/app/build/intermediates/res/merged/debug/values-zh-rCN_values-zh-rCN.arsc.flat
new file mode 100644
index 0000000..e82c6f5
Binary files /dev/null and b/src/src/app/build/intermediates/res/merged/debug/values-zh-rCN_values-zh-rCN.arsc.flat differ
diff --git a/src/src/app/build/intermediates/res/merged/debug/values-zh-rHK_values-zh-rHK.arsc.flat b/src/src/app/build/intermediates/res/merged/debug/values-zh-rHK_values-zh-rHK.arsc.flat
new file mode 100644
index 0000000..ccc3079
Binary files /dev/null and b/src/src/app/build/intermediates/res/merged/debug/values-zh-rHK_values-zh-rHK.arsc.flat differ
diff --git a/src/src/app/build/intermediates/res/merged/debug/values-zh-rTW_values-zh-rTW.arsc.flat b/src/src/app/build/intermediates/res/merged/debug/values-zh-rTW_values-zh-rTW.arsc.flat
new file mode 100644
index 0000000..76c92b5
Binary files /dev/null and b/src/src/app/build/intermediates/res/merged/debug/values-zh-rTW_values-zh-rTW.arsc.flat differ
diff --git a/src/src/app/build/intermediates/res/merged/debug/values-zu_values-zu.arsc.flat b/src/src/app/build/intermediates/res/merged/debug/values-zu_values-zu.arsc.flat
new file mode 100644
index 0000000..4085d01
Binary files /dev/null and b/src/src/app/build/intermediates/res/merged/debug/values-zu_values-zu.arsc.flat differ
diff --git a/src/src/app/build/intermediates/res/merged/debug/values_values.arsc.flat b/src/src/app/build/intermediates/res/merged/debug/values_values.arsc.flat
new file mode 100644
index 0000000..36d4789
Binary files /dev/null and b/src/src/app/build/intermediates/res/merged/debug/values_values.arsc.flat differ
diff --git a/src/src/app/build/intermediates/res/merged/debug/xml_preferences.xml.flat b/src/src/app/build/intermediates/res/merged/debug/xml_preferences.xml.flat
new file mode 100644
index 0000000..970a319
Binary files /dev/null and b/src/src/app/build/intermediates/res/merged/debug/xml_preferences.xml.flat differ
diff --git a/src/src/app/build/intermediates/res/merged/debug/xml_searchable.xml.flat b/src/src/app/build/intermediates/res/merged/debug/xml_searchable.xml.flat
new file mode 100644
index 0000000..dfe6628
Binary files /dev/null and b/src/src/app/build/intermediates/res/merged/debug/xml_searchable.xml.flat differ
diff --git a/src/src/app/build/intermediates/res/merged/debug/xml_widget_2x_info.xml.flat b/src/src/app/build/intermediates/res/merged/debug/xml_widget_2x_info.xml.flat
new file mode 100644
index 0000000..248df4d
Binary files /dev/null and b/src/src/app/build/intermediates/res/merged/debug/xml_widget_2x_info.xml.flat differ
diff --git a/src/src/app/build/intermediates/res/merged/debug/xml_widget_4x_info.xml.flat b/src/src/app/build/intermediates/res/merged/debug/xml_widget_4x_info.xml.flat
new file mode 100644
index 0000000..f21db74
Binary files /dev/null and b/src/src/app/build/intermediates/res/merged/debug/xml_widget_4x_info.xml.flat differ
diff --git a/src/src/app/build/intermediates/runtime_symbol_list/debug/R.txt b/src/src/app/build/intermediates/runtime_symbol_list/debug/R.txt
new file mode 100644
index 0000000..27330c6
--- /dev/null
+++ b/src/src/app/build/intermediates/runtime_symbol_list/debug/R.txt
@@ -0,0 +1,1929 @@
+int anim abc_fade_in 0x7f010000
+int anim abc_fade_out 0x7f010001
+int anim abc_grow_fade_in_from_bottom 0x7f010002
+int anim abc_popup_enter 0x7f010003
+int anim abc_popup_exit 0x7f010004
+int anim abc_shrink_fade_out_from_bottom 0x7f010005
+int anim abc_slide_in_bottom 0x7f010006
+int anim abc_slide_in_top 0x7f010007
+int anim abc_slide_out_bottom 0x7f010008
+int anim abc_slide_out_top 0x7f010009
+int anim abc_tooltip_enter 0x7f01000a
+int anim abc_tooltip_exit 0x7f01000b
+int array format_for_exported_note 0x7f020000
+int array menu_share_ways 0x7f020001
+int attr actionBarDivider 0x7f030000
+int attr actionBarItemBackground 0x7f030001
+int attr actionBarPopupTheme 0x7f030002
+int attr actionBarSize 0x7f030003
+int attr actionBarSplitStyle 0x7f030004
+int attr actionBarStyle 0x7f030005
+int attr actionBarTabBarStyle 0x7f030006
+int attr actionBarTabStyle 0x7f030007
+int attr actionBarTabTextStyle 0x7f030008
+int attr actionBarTheme 0x7f030009
+int attr actionBarWidgetTheme 0x7f03000a
+int attr actionButtonStyle 0x7f03000b
+int attr actionDropDownStyle 0x7f03000c
+int attr actionLayout 0x7f03000d
+int attr actionMenuTextAppearance 0x7f03000e
+int attr actionMenuTextColor 0x7f03000f
+int attr actionModeBackground 0x7f030010
+int attr actionModeCloseButtonStyle 0x7f030011
+int attr actionModeCloseDrawable 0x7f030012
+int attr actionModeCopyDrawable 0x7f030013
+int attr actionModeCutDrawable 0x7f030014
+int attr actionModeFindDrawable 0x7f030015
+int attr actionModePasteDrawable 0x7f030016
+int attr actionModePopupWindowStyle 0x7f030017
+int attr actionModeSelectAllDrawable 0x7f030018
+int attr actionModeShareDrawable 0x7f030019
+int attr actionModeSplitBackground 0x7f03001a
+int attr actionModeStyle 0x7f03001b
+int attr actionModeWebSearchDrawable 0x7f03001c
+int attr actionOverflowButtonStyle 0x7f03001d
+int attr actionOverflowMenuStyle 0x7f03001e
+int attr actionProviderClass 0x7f03001f
+int attr actionViewClass 0x7f030020
+int attr activityChooserViewStyle 0x7f030021
+int attr alertDialogButtonGroupStyle 0x7f030022
+int attr alertDialogCenterButtons 0x7f030023
+int attr alertDialogStyle 0x7f030024
+int attr alertDialogTheme 0x7f030025
+int attr allowStacking 0x7f030026
+int attr alpha 0x7f030027
+int attr alphabeticModifiers 0x7f030028
+int attr arrowHeadLength 0x7f030029
+int attr arrowShaftLength 0x7f03002a
+int attr autoCompleteTextViewStyle 0x7f03002b
+int attr autoSizeMaxTextSize 0x7f03002c
+int attr autoSizeMinTextSize 0x7f03002d
+int attr autoSizePresetSizes 0x7f03002e
+int attr autoSizeStepGranularity 0x7f03002f
+int attr autoSizeTextType 0x7f030030
+int attr background 0x7f030031
+int attr backgroundSplit 0x7f030032
+int attr backgroundStacked 0x7f030033
+int attr backgroundTint 0x7f030034
+int attr backgroundTintMode 0x7f030035
+int attr barLength 0x7f030036
+int attr borderlessButtonStyle 0x7f030037
+int attr buttonBarButtonStyle 0x7f030038
+int attr buttonBarNegativeButtonStyle 0x7f030039
+int attr buttonBarNeutralButtonStyle 0x7f03003a
+int attr buttonBarPositiveButtonStyle 0x7f03003b
+int attr buttonBarStyle 0x7f03003c
+int attr buttonGravity 0x7f03003d
+int attr buttonIconDimen 0x7f03003e
+int attr buttonPanelSideLayout 0x7f03003f
+int attr buttonStyle 0x7f030040
+int attr buttonStyleSmall 0x7f030041
+int attr buttonTint 0x7f030042
+int attr buttonTintMode 0x7f030043
+int attr checkboxStyle 0x7f030044
+int attr checkedTextViewStyle 0x7f030045
+int attr closeIcon 0x7f030046
+int attr closeItemLayout 0x7f030047
+int attr collapseContentDescription 0x7f030048
+int attr collapseIcon 0x7f030049
+int attr color 0x7f03004a
+int attr colorAccent 0x7f03004b
+int attr colorBackgroundFloating 0x7f03004c
+int attr colorButtonNormal 0x7f03004d
+int attr colorControlActivated 0x7f03004e
+int attr colorControlHighlight 0x7f03004f
+int attr colorControlNormal 0x7f030050
+int attr colorError 0x7f030051
+int attr colorPrimary 0x7f030052
+int attr colorPrimaryDark 0x7f030053
+int attr colorSwitchThumbNormal 0x7f030054
+int attr commitIcon 0x7f030055
+int attr contentDescription 0x7f030056
+int attr contentInsetEnd 0x7f030057
+int attr contentInsetEndWithActions 0x7f030058
+int attr contentInsetLeft 0x7f030059
+int attr contentInsetRight 0x7f03005a
+int attr contentInsetStart 0x7f03005b
+int attr contentInsetStartWithNavigation 0x7f03005c
+int attr controlBackground 0x7f03005d
+int attr coordinatorLayoutStyle 0x7f03005e
+int attr customNavigationLayout 0x7f03005f
+int attr defaultQueryHint 0x7f030060
+int attr dialogCornerRadius 0x7f030061
+int attr dialogPreferredPadding 0x7f030062
+int attr dialogTheme 0x7f030063
+int attr displayOptions 0x7f030064
+int attr divider 0x7f030065
+int attr dividerHorizontal 0x7f030066
+int attr dividerPadding 0x7f030067
+int attr dividerVertical 0x7f030068
+int attr drawableSize 0x7f030069
+int attr drawerArrowStyle 0x7f03006a
+int attr dropDownListViewStyle 0x7f03006b
+int attr dropdownListPreferredItemHeight 0x7f03006c
+int attr editTextBackground 0x7f03006d
+int attr editTextColor 0x7f03006e
+int attr editTextStyle 0x7f03006f
+int attr elevation 0x7f030070
+int attr expandActivityOverflowButtonDrawable 0x7f030071
+int attr firstBaselineToTopHeight 0x7f030072
+int attr font 0x7f030073
+int attr fontFamily 0x7f030074
+int attr fontProviderAuthority 0x7f030075
+int attr fontProviderCerts 0x7f030076
+int attr fontProviderFetchStrategy 0x7f030077
+int attr fontProviderFetchTimeout 0x7f030078
+int attr fontProviderPackage 0x7f030079
+int attr fontProviderQuery 0x7f03007a
+int attr fontStyle 0x7f03007b
+int attr fontVariationSettings 0x7f03007c
+int attr fontWeight 0x7f03007d
+int attr gapBetweenBars 0x7f03007e
+int attr goIcon 0x7f03007f
+int attr height 0x7f030080
+int attr hideOnContentScroll 0x7f030081
+int attr homeAsUpIndicator 0x7f030082
+int attr homeLayout 0x7f030083
+int attr icon 0x7f030084
+int attr iconTint 0x7f030085
+int attr iconTintMode 0x7f030086
+int attr iconifiedByDefault 0x7f030087
+int attr imageButtonStyle 0x7f030088
+int attr indeterminateProgressStyle 0x7f030089
+int attr initialActivityCount 0x7f03008a
+int attr isLightTheme 0x7f03008b
+int attr itemPadding 0x7f03008c
+int attr keylines 0x7f03008d
+int attr lastBaselineToBottomHeight 0x7f03008e
+int attr layout 0x7f03008f
+int attr layout_anchor 0x7f030090
+int attr layout_anchorGravity 0x7f030091
+int attr layout_behavior 0x7f030092
+int attr layout_dodgeInsetEdges 0x7f030093
+int attr layout_insetEdge 0x7f030094
+int attr layout_keyline 0x7f030095
+int attr lineHeight 0x7f030096
+int attr listChoiceBackgroundIndicator 0x7f030097
+int attr listDividerAlertDialog 0x7f030098
+int attr listItemLayout 0x7f030099
+int attr listLayout 0x7f03009a
+int attr listMenuViewStyle 0x7f03009b
+int attr listPopupWindowStyle 0x7f03009c
+int attr listPreferredItemHeight 0x7f03009d
+int attr listPreferredItemHeightLarge 0x7f03009e
+int attr listPreferredItemHeightSmall 0x7f03009f
+int attr listPreferredItemPaddingLeft 0x7f0300a0
+int attr listPreferredItemPaddingRight 0x7f0300a1
+int attr logo 0x7f0300a2
+int attr logoDescription 0x7f0300a3
+int attr maxButtonHeight 0x7f0300a4
+int attr measureWithLargestChild 0x7f0300a5
+int attr multiChoiceItemLayout 0x7f0300a6
+int attr navigationContentDescription 0x7f0300a7
+int attr navigationIcon 0x7f0300a8
+int attr navigationMode 0x7f0300a9
+int attr numericModifiers 0x7f0300aa
+int attr overlapAnchor 0x7f0300ab
+int attr paddingBottomNoButtons 0x7f0300ac
+int attr paddingEnd 0x7f0300ad
+int attr paddingStart 0x7f0300ae
+int attr paddingTopNoTitle 0x7f0300af
+int attr panelBackground 0x7f0300b0
+int attr panelMenuListTheme 0x7f0300b1
+int attr panelMenuListWidth 0x7f0300b2
+int attr popupMenuStyle 0x7f0300b3
+int attr popupTheme 0x7f0300b4
+int attr popupWindowStyle 0x7f0300b5
+int attr preserveIconSpacing 0x7f0300b6
+int attr progressBarPadding 0x7f0300b7
+int attr progressBarStyle 0x7f0300b8
+int attr queryBackground 0x7f0300b9
+int attr queryHint 0x7f0300ba
+int attr radioButtonStyle 0x7f0300bb
+int attr ratingBarStyle 0x7f0300bc
+int attr ratingBarStyleIndicator 0x7f0300bd
+int attr ratingBarStyleSmall 0x7f0300be
+int attr searchHintIcon 0x7f0300bf
+int attr searchIcon 0x7f0300c0
+int attr searchViewStyle 0x7f0300c1
+int attr seekBarStyle 0x7f0300c2
+int attr selectableItemBackground 0x7f0300c3
+int attr selectableItemBackgroundBorderless 0x7f0300c4
+int attr showAsAction 0x7f0300c5
+int attr showDividers 0x7f0300c6
+int attr showText 0x7f0300c7
+int attr showTitle 0x7f0300c8
+int attr singleChoiceItemLayout 0x7f0300c9
+int attr spinBars 0x7f0300ca
+int attr spinnerDropDownItemStyle 0x7f0300cb
+int attr spinnerStyle 0x7f0300cc
+int attr splitTrack 0x7f0300cd
+int attr srcCompat 0x7f0300ce
+int attr state_above_anchor 0x7f0300cf
+int attr statusBarBackground 0x7f0300d0
+int attr subMenuArrow 0x7f0300d1
+int attr submitBackground 0x7f0300d2
+int attr subtitle 0x7f0300d3
+int attr subtitleTextAppearance 0x7f0300d4
+int attr subtitleTextColor 0x7f0300d5
+int attr subtitleTextStyle 0x7f0300d6
+int attr suggestionRowLayout 0x7f0300d7
+int attr switchMinWidth 0x7f0300d8
+int attr switchPadding 0x7f0300d9
+int attr switchStyle 0x7f0300da
+int attr switchTextAppearance 0x7f0300db
+int attr textAllCaps 0x7f0300dc
+int attr textAppearanceLargePopupMenu 0x7f0300dd
+int attr textAppearanceListItem 0x7f0300de
+int attr textAppearanceListItemSecondary 0x7f0300df
+int attr textAppearanceListItemSmall 0x7f0300e0
+int attr textAppearancePopupMenuHeader 0x7f0300e1
+int attr textAppearanceSearchResultSubtitle 0x7f0300e2
+int attr textAppearanceSearchResultTitle 0x7f0300e3
+int attr textAppearanceSmallPopupMenu 0x7f0300e4
+int attr textColorAlertDialogListItem 0x7f0300e5
+int attr textColorSearchUrl 0x7f0300e6
+int attr theme 0x7f0300e7
+int attr thickness 0x7f0300e8
+int attr thumbTextPadding 0x7f0300e9
+int attr thumbTint 0x7f0300ea
+int attr thumbTintMode 0x7f0300eb
+int attr tickMark 0x7f0300ec
+int attr tickMarkTint 0x7f0300ed
+int attr tickMarkTintMode 0x7f0300ee
+int attr tint 0x7f0300ef
+int attr tintMode 0x7f0300f0
+int attr title 0x7f0300f1
+int attr titleMargin 0x7f0300f2
+int attr titleMarginBottom 0x7f0300f3
+int attr titleMarginEnd 0x7f0300f4
+int attr titleMarginStart 0x7f0300f5
+int attr titleMarginTop 0x7f0300f6
+int attr titleMargins 0x7f0300f7
+int attr titleTextAppearance 0x7f0300f8
+int attr titleTextColor 0x7f0300f9
+int attr titleTextStyle 0x7f0300fa
+int attr toolbarNavigationButtonStyle 0x7f0300fb
+int attr toolbarStyle 0x7f0300fc
+int attr tooltipForegroundColor 0x7f0300fd
+int attr tooltipFrameBackground 0x7f0300fe
+int attr tooltipText 0x7f0300ff
+int attr track 0x7f030100
+int attr trackTint 0x7f030101
+int attr trackTintMode 0x7f030102
+int attr ttcIndex 0x7f030103
+int attr viewInflaterClass 0x7f030104
+int attr voiceIcon 0x7f030105
+int attr windowActionBar 0x7f030106
+int attr windowActionBarOverlay 0x7f030107
+int attr windowActionModeOverlay 0x7f030108
+int attr windowFixedHeightMajor 0x7f030109
+int attr windowFixedHeightMinor 0x7f03010a
+int attr windowFixedWidthMajor 0x7f03010b
+int attr windowFixedWidthMinor 0x7f03010c
+int attr windowMinWidthMajor 0x7f03010d
+int attr windowMinWidthMinor 0x7f03010e
+int attr windowNoTitle 0x7f03010f
+int bool abc_action_bar_embed_tabs 0x7f040000
+int bool abc_allow_stacked_button_bar 0x7f040001
+int bool abc_config_actionMenuItemAllCaps 0x7f040002
+int color abc_background_cache_hint_selector_material_dark 0x7f050000
+int color abc_background_cache_hint_selector_material_light 0x7f050001
+int color abc_btn_colored_borderless_text_material 0x7f050002
+int color abc_btn_colored_text_material 0x7f050003
+int color abc_color_highlight_material 0x7f050004
+int color abc_hint_foreground_material_dark 0x7f050005
+int color abc_hint_foreground_material_light 0x7f050006
+int color abc_input_method_navigation_guard 0x7f050007
+int color abc_primary_text_disable_only_material_dark 0x7f050008
+int color abc_primary_text_disable_only_material_light 0x7f050009
+int color abc_primary_text_material_dark 0x7f05000a
+int color abc_primary_text_material_light 0x7f05000b
+int color abc_search_url_text 0x7f05000c
+int color abc_search_url_text_normal 0x7f05000d
+int color abc_search_url_text_pressed 0x7f05000e
+int color abc_search_url_text_selected 0x7f05000f
+int color abc_secondary_text_material_dark 0x7f050010
+int color abc_secondary_text_material_light 0x7f050011
+int color abc_tint_btn_checkable 0x7f050012
+int color abc_tint_default 0x7f050013
+int color abc_tint_edittext 0x7f050014
+int color abc_tint_seek_thumb 0x7f050015
+int color abc_tint_spinner 0x7f050016
+int color abc_tint_switch_track 0x7f050017
+int color accent_material_dark 0x7f050018
+int color accent_material_light 0x7f050019
+int color background_floating_material_dark 0x7f05001a
+int color background_floating_material_light 0x7f05001b
+int color background_material_dark 0x7f05001c
+int color background_material_light 0x7f05001d
+int color bright_foreground_disabled_material_dark 0x7f05001e
+int color bright_foreground_disabled_material_light 0x7f05001f
+int color bright_foreground_inverse_material_dark 0x7f050020
+int color bright_foreground_inverse_material_light 0x7f050021
+int color bright_foreground_material_dark 0x7f050022
+int color bright_foreground_material_light 0x7f050023
+int color button_material_dark 0x7f050024
+int color button_material_light 0x7f050025
+int color dim_foreground_disabled_material_dark 0x7f050026
+int color dim_foreground_disabled_material_light 0x7f050027
+int color dim_foreground_material_dark 0x7f050028
+int color dim_foreground_material_light 0x7f050029
+int color error_color_material_dark 0x7f05002a
+int color error_color_material_light 0x7f05002b
+int color foreground_material_dark 0x7f05002c
+int color foreground_material_light 0x7f05002d
+int color highlighted_text_material_dark 0x7f05002e
+int color highlighted_text_material_light 0x7f05002f
+int color material_blue_grey_800 0x7f050030
+int color material_blue_grey_900 0x7f050031
+int color material_blue_grey_950 0x7f050032
+int color material_deep_teal_200 0x7f050033
+int color material_deep_teal_500 0x7f050034
+int color material_grey_100 0x7f050035
+int color material_grey_300 0x7f050036
+int color material_grey_50 0x7f050037
+int color material_grey_600 0x7f050038
+int color material_grey_800 0x7f050039
+int color material_grey_850 0x7f05003a
+int color material_grey_900 0x7f05003b
+int color notification_action_color_filter 0x7f05003c
+int color notification_icon_bg_color 0x7f05003d
+int color notification_material_background_media_default_color 0x7f05003e
+int color primary_dark_material_dark 0x7f05003f
+int color primary_dark_material_light 0x7f050040
+int color primary_material_dark 0x7f050041
+int color primary_material_light 0x7f050042
+int color primary_text_dark 0x7f050043
+int color primary_text_default_material_dark 0x7f050044
+int color primary_text_default_material_light 0x7f050045
+int color primary_text_disabled_material_dark 0x7f050046
+int color primary_text_disabled_material_light 0x7f050047
+int color ripple_material_dark 0x7f050048
+int color ripple_material_light 0x7f050049
+int color secondary_text_dark 0x7f05004a
+int color secondary_text_default_material_dark 0x7f05004b
+int color secondary_text_default_material_light 0x7f05004c
+int color secondary_text_disabled_material_dark 0x7f05004d
+int color secondary_text_disabled_material_light 0x7f05004e
+int color switch_thumb_disabled_material_dark 0x7f05004f
+int color switch_thumb_disabled_material_light 0x7f050050
+int color switch_thumb_material_dark 0x7f050051
+int color switch_thumb_material_light 0x7f050052
+int color switch_thumb_normal_material_dark 0x7f050053
+int color switch_thumb_normal_material_light 0x7f050054
+int color tooltip_background_dark 0x7f050055
+int color tooltip_background_light 0x7f050056
+int color user_query_highlight 0x7f050057
+int dimen abc_action_bar_content_inset_material 0x7f060000
+int dimen abc_action_bar_content_inset_with_nav 0x7f060001
+int dimen abc_action_bar_default_height_material 0x7f060002
+int dimen abc_action_bar_default_padding_end_material 0x7f060003
+int dimen abc_action_bar_default_padding_start_material 0x7f060004
+int dimen abc_action_bar_elevation_material 0x7f060005
+int dimen abc_action_bar_icon_vertical_padding_material 0x7f060006
+int dimen abc_action_bar_overflow_padding_end_material 0x7f060007
+int dimen abc_action_bar_overflow_padding_start_material 0x7f060008
+int dimen abc_action_bar_stacked_max_height 0x7f060009
+int dimen abc_action_bar_stacked_tab_max_width 0x7f06000a
+int dimen abc_action_bar_subtitle_bottom_margin_material 0x7f06000b
+int dimen abc_action_bar_subtitle_top_margin_material 0x7f06000c
+int dimen abc_action_button_min_height_material 0x7f06000d
+int dimen abc_action_button_min_width_material 0x7f06000e
+int dimen abc_action_button_min_width_overflow_material 0x7f06000f
+int dimen abc_alert_dialog_button_bar_height 0x7f060010
+int dimen abc_alert_dialog_button_dimen 0x7f060011
+int dimen abc_button_inset_horizontal_material 0x7f060012
+int dimen abc_button_inset_vertical_material 0x7f060013
+int dimen abc_button_padding_horizontal_material 0x7f060014
+int dimen abc_button_padding_vertical_material 0x7f060015
+int dimen abc_cascading_menus_min_smallest_width 0x7f060016
+int dimen abc_config_prefDialogWidth 0x7f060017
+int dimen abc_control_corner_material 0x7f060018
+int dimen abc_control_inset_material 0x7f060019
+int dimen abc_control_padding_material 0x7f06001a
+int dimen abc_dialog_corner_radius_material 0x7f06001b
+int dimen abc_dialog_fixed_height_major 0x7f06001c
+int dimen abc_dialog_fixed_height_minor 0x7f06001d
+int dimen abc_dialog_fixed_width_major 0x7f06001e
+int dimen abc_dialog_fixed_width_minor 0x7f06001f
+int dimen abc_dialog_list_padding_bottom_no_buttons 0x7f060020
+int dimen abc_dialog_list_padding_top_no_title 0x7f060021
+int dimen abc_dialog_min_width_major 0x7f060022
+int dimen abc_dialog_min_width_minor 0x7f060023
+int dimen abc_dialog_padding_material 0x7f060024
+int dimen abc_dialog_padding_top_material 0x7f060025
+int dimen abc_dialog_title_divider_material 0x7f060026
+int dimen abc_disabled_alpha_material_dark 0x7f060027
+int dimen abc_disabled_alpha_material_light 0x7f060028
+int dimen abc_dropdownitem_icon_width 0x7f060029
+int dimen abc_dropdownitem_text_padding_left 0x7f06002a
+int dimen abc_dropdownitem_text_padding_right 0x7f06002b
+int dimen abc_edit_text_inset_bottom_material 0x7f06002c
+int dimen abc_edit_text_inset_horizontal_material 0x7f06002d
+int dimen abc_edit_text_inset_top_material 0x7f06002e
+int dimen abc_floating_window_z 0x7f06002f
+int dimen abc_list_item_padding_horizontal_material 0x7f060030
+int dimen abc_panel_menu_list_width 0x7f060031
+int dimen abc_progress_bar_height_material 0x7f060032
+int dimen abc_search_view_preferred_height 0x7f060033
+int dimen abc_search_view_preferred_width 0x7f060034
+int dimen abc_seekbar_track_background_height_material 0x7f060035
+int dimen abc_seekbar_track_progress_height_material 0x7f060036
+int dimen abc_select_dialog_padding_start_material 0x7f060037
+int dimen abc_switch_padding 0x7f060038
+int dimen abc_text_size_body_1_material 0x7f060039
+int dimen abc_text_size_body_2_material 0x7f06003a
+int dimen abc_text_size_button_material 0x7f06003b
+int dimen abc_text_size_caption_material 0x7f06003c
+int dimen abc_text_size_display_1_material 0x7f06003d
+int dimen abc_text_size_display_2_material 0x7f06003e
+int dimen abc_text_size_display_3_material 0x7f06003f
+int dimen abc_text_size_display_4_material 0x7f060040
+int dimen abc_text_size_headline_material 0x7f060041
+int dimen abc_text_size_large_material 0x7f060042
+int dimen abc_text_size_medium_material 0x7f060043
+int dimen abc_text_size_menu_header_material 0x7f060044
+int dimen abc_text_size_menu_material 0x7f060045
+int dimen abc_text_size_small_material 0x7f060046
+int dimen abc_text_size_subhead_material 0x7f060047
+int dimen abc_text_size_subtitle_material_toolbar 0x7f060048
+int dimen abc_text_size_title_material 0x7f060049
+int dimen abc_text_size_title_material_toolbar 0x7f06004a
+int dimen compat_button_inset_horizontal_material 0x7f06004b
+int dimen compat_button_inset_vertical_material 0x7f06004c
+int dimen compat_button_padding_horizontal_material 0x7f06004d
+int dimen compat_button_padding_vertical_material 0x7f06004e
+int dimen compat_control_corner_material 0x7f06004f
+int dimen compat_notification_large_icon_max_height 0x7f060050
+int dimen compat_notification_large_icon_max_width 0x7f060051
+int dimen disabled_alpha_material_dark 0x7f060052
+int dimen disabled_alpha_material_light 0x7f060053
+int dimen highlight_alpha_material_colored 0x7f060054
+int dimen highlight_alpha_material_dark 0x7f060055
+int dimen highlight_alpha_material_light 0x7f060056
+int dimen hint_alpha_material_dark 0x7f060057
+int dimen hint_alpha_material_light 0x7f060058
+int dimen hint_pressed_alpha_material_dark 0x7f060059
+int dimen hint_pressed_alpha_material_light 0x7f06005a
+int dimen notification_action_icon_size 0x7f06005b
+int dimen notification_action_text_size 0x7f06005c
+int dimen notification_big_circle_margin 0x7f06005d
+int dimen notification_content_margin_start 0x7f06005e
+int dimen notification_large_icon_height 0x7f06005f
+int dimen notification_large_icon_width 0x7f060060
+int dimen notification_main_column_padding_top 0x7f060061
+int dimen notification_media_narrow_margin 0x7f060062
+int dimen notification_right_icon_size 0x7f060063
+int dimen notification_right_side_padding_top 0x7f060064
+int dimen notification_small_icon_background_padding 0x7f060065
+int dimen notification_small_icon_size_as_large 0x7f060066
+int dimen notification_subtext_size 0x7f060067
+int dimen notification_top_pad 0x7f060068
+int dimen notification_top_pad_large_text 0x7f060069
+int dimen subtitle_corner_radius 0x7f06006a
+int dimen subtitle_outline_width 0x7f06006b
+int dimen subtitle_shadow_offset 0x7f06006c
+int dimen subtitle_shadow_radius 0x7f06006d
+int dimen text_font_size_large 0x7f06006e
+int dimen text_font_size_medium 0x7f06006f
+int dimen text_font_size_normal 0x7f060070
+int dimen text_font_size_small 0x7f060071
+int dimen text_font_size_super 0x7f060072
+int dimen tooltip_corner_radius 0x7f060073
+int dimen tooltip_horizontal_padding 0x7f060074
+int dimen tooltip_margin 0x7f060075
+int dimen tooltip_precise_anchor_extra_offset 0x7f060076
+int dimen tooltip_precise_anchor_threshold 0x7f060077
+int dimen tooltip_vertical_padding 0x7f060078
+int dimen tooltip_y_offset_non_touch 0x7f060079
+int dimen tooltip_y_offset_touch 0x7f06007a
+int drawable abc_ab_share_pack_mtrl_alpha 0x7f070000
+int drawable abc_action_bar_item_background_material 0x7f070001
+int drawable abc_btn_borderless_material 0x7f070002
+int drawable abc_btn_check_material 0x7f070003
+int drawable abc_btn_check_to_on_mtrl_000 0x7f070004
+int drawable abc_btn_check_to_on_mtrl_015 0x7f070005
+int drawable abc_btn_colored_material 0x7f070006
+int drawable abc_btn_default_mtrl_shape 0x7f070007
+int drawable abc_btn_radio_material 0x7f070008
+int drawable abc_btn_radio_to_on_mtrl_000 0x7f070009
+int drawable abc_btn_radio_to_on_mtrl_015 0x7f07000a
+int drawable abc_btn_switch_to_on_mtrl_00001 0x7f07000b
+int drawable abc_btn_switch_to_on_mtrl_00012 0x7f07000c
+int drawable abc_cab_background_internal_bg 0x7f07000d
+int drawable abc_cab_background_top_material 0x7f07000e
+int drawable abc_cab_background_top_mtrl_alpha 0x7f07000f
+int drawable abc_control_background_material 0x7f070010
+int drawable abc_dialog_material_background 0x7f070011
+int drawable abc_edit_text_material 0x7f070012
+int drawable abc_ic_ab_back_material 0x7f070013
+int drawable abc_ic_arrow_drop_right_black_24dp 0x7f070014
+int drawable abc_ic_clear_material 0x7f070015
+int drawable abc_ic_commit_search_api_mtrl_alpha 0x7f070016
+int drawable abc_ic_go_search_api_material 0x7f070017
+int drawable abc_ic_menu_copy_mtrl_am_alpha 0x7f070018
+int drawable abc_ic_menu_cut_mtrl_alpha 0x7f070019
+int drawable abc_ic_menu_overflow_material 0x7f07001a
+int drawable abc_ic_menu_paste_mtrl_am_alpha 0x7f07001b
+int drawable abc_ic_menu_selectall_mtrl_alpha 0x7f07001c
+int drawable abc_ic_menu_share_mtrl_alpha 0x7f07001d
+int drawable abc_ic_search_api_material 0x7f07001e
+int drawable abc_ic_star_black_16dp 0x7f07001f
+int drawable abc_ic_star_black_36dp 0x7f070020
+int drawable abc_ic_star_black_48dp 0x7f070021
+int drawable abc_ic_star_half_black_16dp 0x7f070022
+int drawable abc_ic_star_half_black_36dp 0x7f070023
+int drawable abc_ic_star_half_black_48dp 0x7f070024
+int drawable abc_ic_voice_search_api_material 0x7f070025
+int drawable abc_item_background_holo_dark 0x7f070026
+int drawable abc_item_background_holo_light 0x7f070027
+int drawable abc_list_divider_material 0x7f070028
+int drawable abc_list_divider_mtrl_alpha 0x7f070029
+int drawable abc_list_focused_holo 0x7f07002a
+int drawable abc_list_longpressed_holo 0x7f07002b
+int drawable abc_list_pressed_holo_dark 0x7f07002c
+int drawable abc_list_pressed_holo_light 0x7f07002d
+int drawable abc_list_selector_background_transition_holo_dark 0x7f07002e
+int drawable abc_list_selector_background_transition_holo_light 0x7f07002f
+int drawable abc_list_selector_disabled_holo_dark 0x7f070030
+int drawable abc_list_selector_disabled_holo_light 0x7f070031
+int drawable abc_list_selector_holo_dark 0x7f070032
+int drawable abc_list_selector_holo_light 0x7f070033
+int drawable abc_menu_hardkey_panel_mtrl_mult 0x7f070034
+int drawable abc_popup_background_mtrl_mult 0x7f070035
+int drawable abc_ratingbar_indicator_material 0x7f070036
+int drawable abc_ratingbar_material 0x7f070037
+int drawable abc_ratingbar_small_material 0x7f070038
+int drawable abc_scrubber_control_off_mtrl_alpha 0x7f070039
+int drawable abc_scrubber_control_to_pressed_mtrl_000 0x7f07003a
+int drawable abc_scrubber_control_to_pressed_mtrl_005 0x7f07003b
+int drawable abc_scrubber_primary_mtrl_alpha 0x7f07003c
+int drawable abc_scrubber_track_mtrl_alpha 0x7f07003d
+int drawable abc_seekbar_thumb_material 0x7f07003e
+int drawable abc_seekbar_tick_mark_material 0x7f07003f
+int drawable abc_seekbar_track_material 0x7f070040
+int drawable abc_spinner_mtrl_am_alpha 0x7f070041
+int drawable abc_spinner_textfield_background_material 0x7f070042
+int drawable abc_switch_thumb_material 0x7f070043
+int drawable abc_switch_track_mtrl_alpha 0x7f070044
+int drawable abc_tab_indicator_material 0x7f070045
+int drawable abc_tab_indicator_mtrl_alpha 0x7f070046
+int drawable abc_text_cursor_material 0x7f070047
+int drawable abc_text_select_handle_left_mtrl_dark 0x7f070048
+int drawable abc_text_select_handle_left_mtrl_light 0x7f070049
+int drawable abc_text_select_handle_middle_mtrl_dark 0x7f07004a
+int drawable abc_text_select_handle_middle_mtrl_light 0x7f07004b
+int drawable abc_text_select_handle_right_mtrl_dark 0x7f07004c
+int drawable abc_text_select_handle_right_mtrl_light 0x7f07004d
+int drawable abc_textfield_activated_mtrl_alpha 0x7f07004e
+int drawable abc_textfield_default_mtrl_alpha 0x7f07004f
+int drawable abc_textfield_search_activated_mtrl_alpha 0x7f070050
+int drawable abc_textfield_search_default_mtrl_alpha 0x7f070051
+int drawable abc_textfield_search_material 0x7f070052
+int drawable abc_vector_test 0x7f070053
+int drawable bg_btn_set_color 0x7f070054
+int drawable bg_color_btn_mask 0x7f070055
+int drawable call_record 0x7f070056
+int drawable clock 0x7f070057
+int drawable delete 0x7f070058
+int drawable dropdown_icon 0x7f070059
+int drawable edit_blue 0x7f07005a
+int drawable edit_green 0x7f07005b
+int drawable edit_red 0x7f07005c
+int drawable edit_title_blue 0x7f07005d
+int drawable edit_title_green 0x7f07005e
+int drawable edit_title_red 0x7f07005f
+int drawable edit_title_white 0x7f070060
+int drawable edit_title_yellow 0x7f070061
+int drawable edit_white 0x7f070062
+int drawable edit_yellow 0x7f070063
+int drawable font_large 0x7f070064
+int drawable font_normal 0x7f070065
+int drawable font_size_selector_bg 0x7f070066
+int drawable font_small 0x7f070067
+int drawable font_super 0x7f070068
+int drawable huaban 0x7f070069
+int drawable icon_app 0x7f07006a
+int drawable key 0x7f07006b
+int drawable list_background 0x7f07006c
+int drawable list_blue_down 0x7f07006d
+int drawable list_blue_middle 0x7f07006e
+int drawable list_blue_single 0x7f07006f
+int drawable list_blue_up 0x7f070070
+int drawable list_folder 0x7f070071
+int drawable list_footer_bg 0x7f070072
+int drawable list_green_down 0x7f070073
+int drawable list_green_middle 0x7f070074
+int drawable list_green_single 0x7f070075
+int drawable list_green_up 0x7f070076
+int drawable list_red_down 0x7f070077
+int drawable list_red_middle 0x7f070078
+int drawable list_red_single 0x7f070079
+int drawable list_red_up 0x7f07007a
+int drawable list_white_down 0x7f07007b
+int drawable list_white_middle 0x7f07007c
+int drawable list_white_single 0x7f07007d
+int drawable list_white_up 0x7f07007e
+int drawable list_yellow_down 0x7f07007f
+int drawable list_yellow_middle 0x7f070080
+int drawable list_yellow_single 0x7f070081
+int drawable list_yellow_up 0x7f070082
+int drawable menu_delete 0x7f070083
+int drawable menu_move 0x7f070084
+int drawable new_note 0x7f070085
+int drawable new_note_normal 0x7f070086
+int drawable new_note_pressed 0x7f070087
+int drawable note_edit_color_selector_panel 0x7f070088
+int drawable notification 0x7f070089
+int drawable notification_action_background 0x7f07008a
+int drawable notification_bg 0x7f07008b
+int drawable notification_bg_low 0x7f07008c
+int drawable notification_bg_low_normal 0x7f07008d
+int drawable notification_bg_low_pressed 0x7f07008e
+int drawable notification_bg_normal 0x7f07008f
+int drawable notification_bg_normal_pressed 0x7f070090
+int drawable notification_icon_background 0x7f070091
+int drawable notification_template_icon_bg 0x7f070092
+int drawable notification_template_icon_low_bg 0x7f070093
+int drawable notification_tile_bg 0x7f070094
+int drawable notify_panel_notification_icon_bg 0x7f070095
+int drawable search_result 0x7f070096
+int drawable selected 0x7f070097
+int drawable title_alert 0x7f070098
+int drawable title_bar_bg 0x7f070099
+int drawable tooltip_frame_dark 0x7f07009a
+int drawable tooltip_frame_light 0x7f07009b
+int drawable widget_2x_blue 0x7f07009c
+int drawable widget_2x_green 0x7f07009d
+int drawable widget_2x_red 0x7f07009e
+int drawable widget_2x_white 0x7f07009f
+int drawable widget_2x_yellow 0x7f0700a0
+int drawable widget_4x_blue 0x7f0700a1
+int drawable widget_4x_green 0x7f0700a2
+int drawable widget_4x_red 0x7f0700a3
+int drawable widget_4x_white 0x7f0700a4
+int drawable widget_4x_yellow 0x7f0700a5
+int id ALT 0x7f080000
+int id CTRL 0x7f080001
+int id CreateContactNote 0x7f080002
+int id CreateEventNote 0x7f080003
+int id CreateNewFolder 0x7f080004
+int id CreateNormalNote 0x7f080005
+int id CreatePasswdNote 0x7f080006
+int id FUNCTION 0x7f080007
+int id META 0x7f080008
+int id SHIFT 0x7f080009
+int id SYM 0x7f08000a
+int id account_dialog_subtitle 0x7f08000b
+int id account_dialog_title 0x7f08000c
+int id action0 0x7f08000d
+int id action_bar 0x7f08000e
+int id action_bar_activity_content 0x7f08000f
+int id action_bar_container 0x7f080010
+int id action_bar_root 0x7f080011
+int id action_bar_spinner 0x7f080012
+int id action_bar_subtitle 0x7f080013
+int id action_bar_title 0x7f080014
+int id action_container 0x7f080015
+int id action_context_bar 0x7f080016
+int id action_divider 0x7f080017
+int id action_image 0x7f080018
+int id action_menu_divider 0x7f080019
+int id action_menu_presenter 0x7f08001a
+int id action_mode_bar 0x7f08001b
+int id action_mode_bar_stub 0x7f08001c
+int id action_mode_close_button 0x7f08001d
+int id action_select_all 0x7f08001e
+int id action_text 0x7f08001f
+int id actions 0x7f080020
+int id activity_chooser_view_content 0x7f080021
+int id add 0x7f080022
+int id alertTitle 0x7f080023
+int id all 0x7f080024
+int id always 0x7f080025
+int id amPm 0x7f080026
+int id async 0x7f080027
+int id beginning 0x7f080028
+int id blocking 0x7f080029
+int id bottom 0x7f08002a
+int id btn_new_note 0x7f08002b
+int id btn_set_bg_color 0x7f08002c
+int id buttonPanel 0x7f08002d
+int id cancel_action 0x7f08002e
+int id cb_edit_item 0x7f08002f
+int id center 0x7f080030
+int id center_horizontal 0x7f080031
+int id center_vertical 0x7f080032
+int id checkbox 0x7f080033
+int id chronometer 0x7f080034
+int id clip_horizontal 0x7f080035
+int id clip_vertical 0x7f080036
+int id collapseActionView 0x7f080037
+int id content 0x7f080038
+int id contentPanel 0x7f080039
+int id custom 0x7f08003a
+int id customPanel 0x7f08003b
+int id date 0x7f08003c
+int id decor_content_parent 0x7f08003d
+int id default_activity_button 0x7f08003e
+int id delete 0x7f08003f
+int id disableHome 0x7f080040
+int id edit_query 0x7f080041
+int id end 0x7f080042
+int id end_padder 0x7f080043
+int id et_edit_text 0x7f080044
+int id et_foler_name 0x7f080045
+int id expand_activities_button 0x7f080046
+int id expanded_menu 0x7f080047
+int id fill 0x7f080048
+int id fill_horizontal 0x7f080049
+int id fill_vertical 0x7f08004a
+int id font_size_selector 0x7f08004b
+int id for_key 0x7f08004c
+int id forever 0x7f08004d
+int id gesture 0x7f08004e
+int id gesture_view 0x7f08004f
+int id gesture_view_name 0x7f080050
+int id group_divider 0x7f080051
+int id home 0x7f080052
+int id homeAsUp 0x7f080053
+int id hour 0x7f080054
+int id icon 0x7f080055
+int id icon_group 0x7f080056
+int id ifRoom 0x7f080057
+int id image 0x7f080058
+int id img_show 0x7f080059
+int id info 0x7f08005a
+int id italic 0x7f08005b
+int id iv_alert_icon 0x7f08005c
+int id iv_bg_blue 0x7f08005d
+int id iv_bg_blue_select 0x7f08005e
+int id iv_bg_green 0x7f08005f
+int id iv_bg_green_select 0x7f080060
+int id iv_bg_red 0x7f080061
+int id iv_bg_red_select 0x7f080062
+int id iv_bg_white 0x7f080063
+int id iv_bg_white_select 0x7f080064
+int id iv_bg_yellow 0x7f080065
+int id iv_bg_yellow_select 0x7f080066
+int id iv_image 0x7f080067
+int id iv_large_select 0x7f080068
+int id iv_medium_select 0x7f080069
+int id iv_small_select 0x7f08006a
+int id iv_super_select 0x7f08006b
+int id left 0x7f08006c
+int id line1 0x7f08006d
+int id line3 0x7f08006e
+int id listMode 0x7f08006f
+int id list_item 0x7f080070
+int id ll_font_large 0x7f080071
+int id ll_font_normal 0x7f080072
+int id ll_font_small 0x7f080073
+int id ll_font_super 0x7f080074
+int id media_actions 0x7f080075
+int id menu_alert 0x7f080076
+int id menu_camera 0x7f080077
+int id menu_delete 0x7f080078
+int id menu_delete_remind 0x7f080079
+int id menu_draw 0x7f08007a
+int id menu_export_text 0x7f08007b
+int id menu_font_size 0x7f08007c
+int id menu_list_mode 0x7f08007d
+int id menu_new_folder 0x7f08007e
+int id menu_new_note 0x7f08007f
+int id menu_search 0x7f080080
+int id menu_send_to_desktop 0x7f080081
+int id menu_setting 0x7f080082
+int id menu_share 0x7f080083
+int id menu_sync 0x7f080084
+int id message 0x7f080085
+int id middle 0x7f080086
+int id minute 0x7f080087
+int id move 0x7f080088
+int id multiply 0x7f080089
+int id myboard 0x7f08008a
+int id navigation_bar 0x7f08008b
+int id never 0x7f08008c
+int id none 0x7f08008d
+int id normal 0x7f08008e
+int id note_bg_color_selector 0x7f08008f
+int id note_edit_list 0x7f080090
+int id note_edit_view 0x7f080091
+int id note_item 0x7f080092
+int id note_title 0x7f080093
+int id notes_list 0x7f080094
+int id notification_background 0x7f080095
+int id notification_main_column 0x7f080096
+int id notification_main_column_container 0x7f080097
+int id parentPanel 0x7f080098
+int id password_hint 0x7f080099
+int id prefenerece_sync_status_textview 0x7f08009a
+int id preference_sync_button 0x7f08009b
+int id progress_circular 0x7f08009c
+int id progress_horizontal 0x7f08009d
+int id radio 0x7f08009e
+int id radioGroup 0x7f08009f
+int id right 0x7f0800a0
+int id right_icon 0x7f0800a1
+int id right_side 0x7f0800a2
+int id screen 0x7f0800a3
+int id scrollIndicatorDown 0x7f0800a4
+int id scrollIndicatorUp 0x7f0800a5
+int id scrollView 0x7f0800a6
+int id search_badge 0x7f0800a7
+int id search_bar 0x7f0800a8
+int id search_button 0x7f0800a9
+int id search_close_btn 0x7f0800aa
+int id search_edit_frame 0x7f0800ab
+int id search_go_btn 0x7f0800ac
+int id search_mag_icon 0x7f0800ad
+int id search_plate 0x7f0800ae
+int id search_src_text 0x7f0800af
+int id search_voice_btn 0x7f0800b0
+int id select_dialog_listview 0x7f0800b1
+int id selection_menu 0x7f0800b2
+int id set_private_pwd 0x7f0800b3
+int id set_private_pwd_confirm 0x7f0800b4
+int id shortcut 0x7f0800b5
+int id showCustom 0x7f0800b6
+int id showHome 0x7f0800b7
+int id showTitle 0x7f0800b8
+int id spacer 0x7f0800b9
+int id split_action_bar 0x7f0800ba
+int id src_atop 0x7f0800bb
+int id src_in 0x7f0800bc
+int id src_over 0x7f0800bd
+int id start 0x7f0800be
+int id status_bar_latest_event_content 0x7f0800bf
+int id submenuarrow 0x7f0800c0
+int id submit_area 0x7f0800c1
+int id sv_note_edit 0x7f0800c2
+int id tabMode 0x7f0800c3
+int id tag_transition_group 0x7f0800c4
+int id tag_unhandled_key_event_manager 0x7f0800c5
+int id tag_unhandled_key_listeners 0x7f0800c6
+int id text 0x7f0800c7
+int id text2 0x7f0800c8
+int id textSpacerNoButtons 0x7f0800c9
+int id textSpacerNoTitle 0x7f0800ca
+int id textView1 0x7f0800cb
+int id textView2 0x7f0800cc
+int id text_num 0x7f0800cd
+int id time 0x7f0800ce
+int id title 0x7f0800cf
+int id titleDividerNoCustom 0x7f0800d0
+int id title_template 0x7f0800d1
+int id top 0x7f0800d2
+int id topPanel 0x7f0800d3
+int id tv_alert_date 0x7f0800d4
+int id tv_folder_name 0x7f0800d5
+int id tv_modified_date 0x7f0800d6
+int id tv_name 0x7f0800d7
+int id tv_time 0x7f0800d8
+int id tv_title 0x7f0800d9
+int id tv_title_bar 0x7f0800da
+int id uniform 0x7f0800db
+int id up 0x7f0800dc
+int id useLogo 0x7f0800dd
+int id widget_bg_image 0x7f0800de
+int id widget_text 0x7f0800df
+int id withText 0x7f0800e0
+int id wrap_content 0x7f0800e1
+int integer abc_config_activityDefaultDur 0x7f090000
+int integer abc_config_activityShortDur 0x7f090001
+int integer cancel_button_image_alpha 0x7f090002
+int integer config_tooltipAnimTime 0x7f090003
+int integer status_bar_notification_info_maxnum 0x7f090004
+int layout abc_action_bar_title_item 0x7f0a0000
+int layout abc_action_bar_up_container 0x7f0a0001
+int layout abc_action_menu_item_layout 0x7f0a0002
+int layout abc_action_menu_layout 0x7f0a0003
+int layout abc_action_mode_bar 0x7f0a0004
+int layout abc_action_mode_close_item_material 0x7f0a0005
+int layout abc_activity_chooser_view 0x7f0a0006
+int layout abc_activity_chooser_view_list_item 0x7f0a0007
+int layout abc_alert_dialog_button_bar_material 0x7f0a0008
+int layout abc_alert_dialog_material 0x7f0a0009
+int layout abc_alert_dialog_title_material 0x7f0a000a
+int layout abc_cascading_menu_item_layout 0x7f0a000b
+int layout abc_dialog_title_material 0x7f0a000c
+int layout abc_expanded_menu_layout 0x7f0a000d
+int layout abc_list_menu_item_checkbox 0x7f0a000e
+int layout abc_list_menu_item_icon 0x7f0a000f
+int layout abc_list_menu_item_layout 0x7f0a0010
+int layout abc_list_menu_item_radio 0x7f0a0011
+int layout abc_popup_menu_header_item_layout 0x7f0a0012
+int layout abc_popup_menu_item_layout 0x7f0a0013
+int layout abc_screen_content_include 0x7f0a0014
+int layout abc_screen_simple 0x7f0a0015
+int layout abc_screen_simple_overlay_action_mode 0x7f0a0016
+int layout abc_screen_toolbar 0x7f0a0017
+int layout abc_search_dropdown_item_icons_2line 0x7f0a0018
+int layout abc_search_view 0x7f0a0019
+int layout abc_select_dialog_material 0x7f0a001a
+int layout abc_tooltip 0x7f0a001b
+int layout account_dialog_title 0x7f0a001c
+int layout add_account_text 0x7f0a001d
+int layout datetime_picker 0x7f0a001e
+int layout dialog_edit_text 0x7f0a001f
+int layout dialog_pwd 0x7f0a0020
+int layout dialog_pwd_confirm 0x7f0a0021
+int layout dialog_save 0x7f0a0022
+int layout folder_list_item 0x7f0a0023
+int layout gesture_setting 0x7f0a0024
+int layout myboard 0x7f0a0025
+int layout note_edit 0x7f0a0026
+int layout note_edit_list_item 0x7f0a0027
+int layout note_item 0x7f0a0028
+int layout note_list 0x7f0a0029
+int layout note_list_dropdown_menu 0x7f0a002a
+int layout note_list_footer 0x7f0a002b
+int layout notification_action 0x7f0a002c
+int layout notification_action_tombstone 0x7f0a002d
+int layout notification_media_action 0x7f0a002e
+int layout notification_media_cancel_action 0x7f0a002f
+int layout notification_template_big_media 0x7f0a0030
+int layout notification_template_big_media_custom 0x7f0a0031
+int layout notification_template_big_media_narrow 0x7f0a0032
+int layout notification_template_big_media_narrow_custom 0x7f0a0033
+int layout notification_template_custom_big 0x7f0a0034
+int layout notification_template_icon_group 0x7f0a0035
+int layout notification_template_lines_media 0x7f0a0036
+int layout notification_template_media 0x7f0a0037
+int layout notification_template_media_custom 0x7f0a0038
+int layout notification_template_part_chronometer 0x7f0a0039
+int layout notification_template_part_time 0x7f0a003a
+int layout select_dialog_item_material 0x7f0a003b
+int layout select_dialog_multichoice_material 0x7f0a003c
+int layout select_dialog_singlechoice_material 0x7f0a003d
+int layout settings_header 0x7f0a003e
+int layout support_simple_spinner_dropdown_item 0x7f0a003f
+int layout widget_2x 0x7f0a0040
+int layout widget_4x 0x7f0a0041
+int menu call_note_edit 0x7f0b0000
+int menu call_record_folder 0x7f0b0001
+int menu note_edit 0x7f0b0002
+int menu note_list 0x7f0b0003
+int menu note_list_dropdown 0x7f0b0004
+int menu note_list_options 0x7f0b0005
+int menu sub_folder 0x7f0b0006
+int plurals search_results_title 0x7f0c0000
+int raw contact 0x7f0d0000
+int raw event 0x7f0d0001
+int raw gestures 0x7f0d0002
+int raw introduction 0x7f0d0003
+int raw passwd 0x7f0d0004
+int string abc_action_bar_home_description 0x7f0e0000
+int string abc_action_bar_up_description 0x7f0e0001
+int string abc_action_menu_overflow_description 0x7f0e0002
+int string abc_action_mode_done 0x7f0e0003
+int string abc_activity_chooser_view_see_all 0x7f0e0004
+int string abc_activitychooserview_choose_application 0x7f0e0005
+int string abc_capital_off 0x7f0e0006
+int string abc_capital_on 0x7f0e0007
+int string abc_font_family_body_1_material 0x7f0e0008
+int string abc_font_family_body_2_material 0x7f0e0009
+int string abc_font_family_button_material 0x7f0e000a
+int string abc_font_family_caption_material 0x7f0e000b
+int string abc_font_family_display_1_material 0x7f0e000c
+int string abc_font_family_display_2_material 0x7f0e000d
+int string abc_font_family_display_3_material 0x7f0e000e
+int string abc_font_family_display_4_material 0x7f0e000f
+int string abc_font_family_headline_material 0x7f0e0010
+int string abc_font_family_menu_material 0x7f0e0011
+int string abc_font_family_subhead_material 0x7f0e0012
+int string abc_font_family_title_material 0x7f0e0013
+int string abc_menu_alt_shortcut_label 0x7f0e0014
+int string abc_menu_ctrl_shortcut_label 0x7f0e0015
+int string abc_menu_delete_shortcut_label 0x7f0e0016
+int string abc_menu_enter_shortcut_label 0x7f0e0017
+int string abc_menu_function_shortcut_label 0x7f0e0018
+int string abc_menu_meta_shortcut_label 0x7f0e0019
+int string abc_menu_shift_shortcut_label 0x7f0e001a
+int string abc_menu_space_shortcut_label 0x7f0e001b
+int string abc_menu_sym_shortcut_label 0x7f0e001c
+int string abc_prepend_shortcut_label 0x7f0e001d
+int string abc_search_hint 0x7f0e001e
+int string abc_searchview_description_clear 0x7f0e001f
+int string abc_searchview_description_query 0x7f0e0020
+int string abc_searchview_description_search 0x7f0e0021
+int string abc_searchview_description_submit 0x7f0e0022
+int string abc_searchview_description_voice 0x7f0e0023
+int string abc_shareactionprovider_share_with 0x7f0e0024
+int string abc_shareactionprovider_share_with_application 0x7f0e0025
+int string abc_toolbar_collapse_description 0x7f0e0026
+int string alert_message_delete_folder 0x7f0e0027
+int string alert_message_delete_note 0x7f0e0028
+int string alert_message_delete_notes 0x7f0e0029
+int string alert_title_delete 0x7f0e002a
+int string app_name 0x7f0e002b
+int string app_widget2x2 0x7f0e002c
+int string app_widget4x4 0x7f0e002d
+int string button_delete 0x7f0e002e
+int string call_record_folder_name 0x7f0e002f
+int string camera 0x7f0e0030
+int string datetime_dialog_cancel 0x7f0e0031
+int string datetime_dialog_ok 0x7f0e0032
+int string default_gesture 0x7f0e0033
+int string delete_remind_time_message 0x7f0e0034
+int string dialog_inputPwd 0x7f0e0035
+int string draw 0x7f0e0036
+int string error_note_empty_for_clock 0x7f0e0037
+int string error_note_empty_for_send_to_desktop 0x7f0e0038
+int string error_note_not_exist 0x7f0e0039
+int string error_sdcard_export 0x7f0e003a
+int string error_sdcard_unmounted 0x7f0e003b
+int string error_sync_cancelled 0x7f0e003c
+int string error_sync_internal 0x7f0e003d
+int string error_sync_network 0x7f0e003e
+int string failed_sdcard_export 0x7f0e003f
+int string file_name_txt_format 0x7f0e0040
+int string file_path 0x7f0e0041
+int string folder_exist 0x7f0e0042
+int string format_date_ymd 0x7f0e0043
+int string format_datetime_mdhm 0x7f0e0044
+int string format_exported_file_location 0x7f0e0045
+int string format_folder_files_count 0x7f0e0046
+int string format_move_notes_to_folder 0x7f0e0047
+int string hint_foler_name 0x7f0e0048
+int string info_note_enter_desktop 0x7f0e0049
+int string menu_LeavePrivate 0x7f0e004a
+int string menu_SetPrivate 0x7f0e004b
+int string menu_alert 0x7f0e004c
+int string menu_countAllNotes 0x7f0e004d
+int string menu_create_folder 0x7f0e004e
+int string menu_delete 0x7f0e004f
+int string menu_deselect_all 0x7f0e0050
+int string menu_export_text 0x7f0e0051
+int string menu_folder_change_name 0x7f0e0052
+int string menu_folder_delete 0x7f0e0053
+int string menu_folder_view 0x7f0e0054
+int string menu_font_large 0x7f0e0055
+int string menu_font_normal 0x7f0e0056
+int string menu_font_size 0x7f0e0057
+int string menu_font_small 0x7f0e0058
+int string menu_font_super 0x7f0e0059
+int string menu_list_mode 0x7f0e005a
+int string menu_move 0x7f0e005b
+int string menu_move_parent_folder 0x7f0e005c
+int string menu_normal_mode 0x7f0e005d
+int string menu_remove_remind 0x7f0e005e
+int string menu_search 0x7f0e005f
+int string menu_select_all 0x7f0e0060
+int string menu_select_none 0x7f0e0061
+int string menu_select_title 0x7f0e0062
+int string menu_send_to_desktop 0x7f0e0063
+int string menu_setting 0x7f0e0064
+int string menu_share 0x7f0e0065
+int string menu_sync 0x7f0e0066
+int string menu_sync_cancel 0x7f0e0067
+int string menu_title_select_folder 0x7f0e0068
+int string note_alert_expired 0x7f0e0069
+int string note_link_email 0x7f0e006a
+int string note_link_other 0x7f0e006b
+int string note_link_tel 0x7f0e006c
+int string note_link_web 0x7f0e006d
+int string notealert_enter 0x7f0e006e
+int string notealert_ok 0x7f0e006f
+int string notelist_menu_new 0x7f0e0070
+int string notelist_string_info 0x7f0e0071
+int string preferences_account_summary 0x7f0e0072
+int string preferences_account_title 0x7f0e0073
+int string preferences_add_account 0x7f0e0074
+int string preferences_bg_random_appear_title 0x7f0e0075
+int string preferences_button_sync_cancel 0x7f0e0076
+int string preferences_button_sync_immediately 0x7f0e0077
+int string preferences_dialog_change_account_title 0x7f0e0078
+int string preferences_dialog_change_account_warn_msg 0x7f0e0079
+int string preferences_dialog_select_account_tips 0x7f0e007a
+int string preferences_dialog_select_account_title 0x7f0e007b
+int string preferences_last_sync_time 0x7f0e007c
+int string preferences_last_sync_time_format 0x7f0e007d
+int string preferences_menu_cancel 0x7f0e007e
+int string preferences_menu_change_account 0x7f0e007f
+int string preferences_menu_remove_account 0x7f0e0080
+int string preferences_title 0x7f0e0081
+int string preferences_toast_cannot_change_account 0x7f0e0082
+int string preferences_toast_success_set_accout 0x7f0e0083
+int string search 0x7f0e0084
+int string search_hint 0x7f0e0085
+int string search_label 0x7f0e0086
+int string search_menu_title 0x7f0e0087
+int string search_setting_description 0x7f0e0088
+int string set_gesture 0x7f0e0089
+int string set_remind_time_message 0x7f0e008a
+int string status_bar_notification_info_overflow 0x7f0e008b
+int string success_sdcard_export 0x7f0e008c
+int string success_sync_account 0x7f0e008d
+int string sync_progress_init_list 0x7f0e008e
+int string sync_progress_login 0x7f0e008f
+int string sync_progress_syncing 0x7f0e0090
+int string take_photo 0x7f0e0091
+int string ticker_cancel 0x7f0e0092
+int string ticker_fail 0x7f0e0093
+int string ticker_success 0x7f0e0094
+int string ticker_syncing 0x7f0e0095
+int string widget_havenot_content 0x7f0e0096
+int string widget_under_visit_mode 0x7f0e0097
+int style AlertDialog_AppCompat 0x7f0f0000
+int style AlertDialog_AppCompat_Light 0x7f0f0001
+int style Animation_AppCompat_Dialog 0x7f0f0002
+int style Animation_AppCompat_DropDownUp 0x7f0f0003
+int style Animation_AppCompat_Tooltip 0x7f0f0004
+int style Base_AlertDialog_AppCompat 0x7f0f0005
+int style Base_AlertDialog_AppCompat_Light 0x7f0f0006
+int style Base_Animation_AppCompat_Dialog 0x7f0f0007
+int style Base_Animation_AppCompat_DropDownUp 0x7f0f0008
+int style Base_Animation_AppCompat_Tooltip 0x7f0f0009
+int style Base_DialogWindowTitle_AppCompat 0x7f0f000a
+int style Base_DialogWindowTitleBackground_AppCompat 0x7f0f000b
+int style Base_TextAppearance_AppCompat 0x7f0f000c
+int style Base_TextAppearance_AppCompat_Body1 0x7f0f000d
+int style Base_TextAppearance_AppCompat_Body2 0x7f0f000e
+int style Base_TextAppearance_AppCompat_Button 0x7f0f000f
+int style Base_TextAppearance_AppCompat_Caption 0x7f0f0010
+int style Base_TextAppearance_AppCompat_Display1 0x7f0f0011
+int style Base_TextAppearance_AppCompat_Display2 0x7f0f0012
+int style Base_TextAppearance_AppCompat_Display3 0x7f0f0013
+int style Base_TextAppearance_AppCompat_Display4 0x7f0f0014
+int style Base_TextAppearance_AppCompat_Headline 0x7f0f0015
+int style Base_TextAppearance_AppCompat_Inverse 0x7f0f0016
+int style Base_TextAppearance_AppCompat_Large 0x7f0f0017
+int style Base_TextAppearance_AppCompat_Large_Inverse 0x7f0f0018
+int style Base_TextAppearance_AppCompat_Light_Widget_PopupMenu_Large 0x7f0f0019
+int style Base_TextAppearance_AppCompat_Light_Widget_PopupMenu_Small 0x7f0f001a
+int style Base_TextAppearance_AppCompat_Medium 0x7f0f001b
+int style Base_TextAppearance_AppCompat_Medium_Inverse 0x7f0f001c
+int style Base_TextAppearance_AppCompat_Menu 0x7f0f001d
+int style Base_TextAppearance_AppCompat_SearchResult 0x7f0f001e
+int style Base_TextAppearance_AppCompat_SearchResult_Subtitle 0x7f0f001f
+int style Base_TextAppearance_AppCompat_SearchResult_Title 0x7f0f0020
+int style Base_TextAppearance_AppCompat_Small 0x7f0f0021
+int style Base_TextAppearance_AppCompat_Small_Inverse 0x7f0f0022
+int style Base_TextAppearance_AppCompat_Subhead 0x7f0f0023
+int style Base_TextAppearance_AppCompat_Subhead_Inverse 0x7f0f0024
+int style Base_TextAppearance_AppCompat_Title 0x7f0f0025
+int style Base_TextAppearance_AppCompat_Title_Inverse 0x7f0f0026
+int style Base_TextAppearance_AppCompat_Tooltip 0x7f0f0027
+int style Base_TextAppearance_AppCompat_Widget_ActionBar_Menu 0x7f0f0028
+int style Base_TextAppearance_AppCompat_Widget_ActionBar_Subtitle 0x7f0f0029
+int style Base_TextAppearance_AppCompat_Widget_ActionBar_Subtitle_Inverse 0x7f0f002a
+int style Base_TextAppearance_AppCompat_Widget_ActionBar_Title 0x7f0f002b
+int style Base_TextAppearance_AppCompat_Widget_ActionBar_Title_Inverse 0x7f0f002c
+int style Base_TextAppearance_AppCompat_Widget_ActionMode_Subtitle 0x7f0f002d
+int style Base_TextAppearance_AppCompat_Widget_ActionMode_Title 0x7f0f002e
+int style Base_TextAppearance_AppCompat_Widget_Button 0x7f0f002f
+int style Base_TextAppearance_AppCompat_Widget_Button_Borderless_Colored 0x7f0f0030
+int style Base_TextAppearance_AppCompat_Widget_Button_Colored 0x7f0f0031
+int style Base_TextAppearance_AppCompat_Widget_Button_Inverse 0x7f0f0032
+int style Base_TextAppearance_AppCompat_Widget_DropDownItem 0x7f0f0033
+int style Base_TextAppearance_AppCompat_Widget_PopupMenu_Header 0x7f0f0034
+int style Base_TextAppearance_AppCompat_Widget_PopupMenu_Large 0x7f0f0035
+int style Base_TextAppearance_AppCompat_Widget_PopupMenu_Small 0x7f0f0036
+int style Base_TextAppearance_AppCompat_Widget_Switch 0x7f0f0037
+int style Base_TextAppearance_AppCompat_Widget_TextView_SpinnerItem 0x7f0f0038
+int style Base_TextAppearance_Widget_AppCompat_ExpandedMenu_Item 0x7f0f0039
+int style Base_TextAppearance_Widget_AppCompat_Toolbar_Subtitle 0x7f0f003a
+int style Base_TextAppearance_Widget_AppCompat_Toolbar_Title 0x7f0f003b
+int style Base_Theme_AppCompat 0x7f0f003c
+int style Base_Theme_AppCompat_CompactMenu 0x7f0f003d
+int style Base_Theme_AppCompat_Dialog 0x7f0f003e
+int style Base_Theme_AppCompat_Dialog_Alert 0x7f0f003f
+int style Base_Theme_AppCompat_Dialog_FixedSize 0x7f0f0040
+int style Base_Theme_AppCompat_Dialog_MinWidth 0x7f0f0041
+int style Base_Theme_AppCompat_DialogWhenLarge 0x7f0f0042
+int style Base_Theme_AppCompat_Light 0x7f0f0043
+int style Base_Theme_AppCompat_Light_DarkActionBar 0x7f0f0044
+int style Base_Theme_AppCompat_Light_Dialog 0x7f0f0045
+int style Base_Theme_AppCompat_Light_Dialog_Alert 0x7f0f0046
+int style Base_Theme_AppCompat_Light_Dialog_FixedSize 0x7f0f0047
+int style Base_Theme_AppCompat_Light_Dialog_MinWidth 0x7f0f0048
+int style Base_Theme_AppCompat_Light_DialogWhenLarge 0x7f0f0049
+int style Base_ThemeOverlay_AppCompat 0x7f0f004a
+int style Base_ThemeOverlay_AppCompat_ActionBar 0x7f0f004b
+int style Base_ThemeOverlay_AppCompat_Dark 0x7f0f004c
+int style Base_ThemeOverlay_AppCompat_Dark_ActionBar 0x7f0f004d
+int style Base_ThemeOverlay_AppCompat_Dialog 0x7f0f004e
+int style Base_ThemeOverlay_AppCompat_Dialog_Alert 0x7f0f004f
+int style Base_ThemeOverlay_AppCompat_Light 0x7f0f0050
+int style Base_V21_Theme_AppCompat 0x7f0f0051
+int style Base_V21_Theme_AppCompat_Dialog 0x7f0f0052
+int style Base_V21_Theme_AppCompat_Light 0x7f0f0053
+int style Base_V21_Theme_AppCompat_Light_Dialog 0x7f0f0054
+int style Base_V21_ThemeOverlay_AppCompat_Dialog 0x7f0f0055
+int style Base_V22_Theme_AppCompat 0x7f0f0056
+int style Base_V22_Theme_AppCompat_Light 0x7f0f0057
+int style Base_V23_Theme_AppCompat 0x7f0f0058
+int style Base_V23_Theme_AppCompat_Light 0x7f0f0059
+int style Base_V26_Theme_AppCompat 0x7f0f005a
+int style Base_V26_Theme_AppCompat_Light 0x7f0f005b
+int style Base_V26_Widget_AppCompat_Toolbar 0x7f0f005c
+int style Base_V28_Theme_AppCompat 0x7f0f005d
+int style Base_V28_Theme_AppCompat_Light 0x7f0f005e
+int style Base_V7_Theme_AppCompat 0x7f0f005f
+int style Base_V7_Theme_AppCompat_Dialog 0x7f0f0060
+int style Base_V7_Theme_AppCompat_Light 0x7f0f0061
+int style Base_V7_Theme_AppCompat_Light_Dialog 0x7f0f0062
+int style Base_V7_ThemeOverlay_AppCompat_Dialog 0x7f0f0063
+int style Base_V7_Widget_AppCompat_AutoCompleteTextView 0x7f0f0064
+int style Base_V7_Widget_AppCompat_EditText 0x7f0f0065
+int style Base_V7_Widget_AppCompat_Toolbar 0x7f0f0066
+int style Base_Widget_AppCompat_ActionBar 0x7f0f0067
+int style Base_Widget_AppCompat_ActionBar_Solid 0x7f0f0068
+int style Base_Widget_AppCompat_ActionBar_TabBar 0x7f0f0069
+int style Base_Widget_AppCompat_ActionBar_TabText 0x7f0f006a
+int style Base_Widget_AppCompat_ActionBar_TabView 0x7f0f006b
+int style Base_Widget_AppCompat_ActionButton 0x7f0f006c
+int style Base_Widget_AppCompat_ActionButton_CloseMode 0x7f0f006d
+int style Base_Widget_AppCompat_ActionButton_Overflow 0x7f0f006e
+int style Base_Widget_AppCompat_ActionMode 0x7f0f006f
+int style Base_Widget_AppCompat_ActivityChooserView 0x7f0f0070
+int style Base_Widget_AppCompat_AutoCompleteTextView 0x7f0f0071
+int style Base_Widget_AppCompat_Button 0x7f0f0072
+int style Base_Widget_AppCompat_Button_Borderless 0x7f0f0073
+int style Base_Widget_AppCompat_Button_Borderless_Colored 0x7f0f0074
+int style Base_Widget_AppCompat_Button_ButtonBar_AlertDialog 0x7f0f0075
+int style Base_Widget_AppCompat_Button_Colored 0x7f0f0076
+int style Base_Widget_AppCompat_Button_Small 0x7f0f0077
+int style Base_Widget_AppCompat_ButtonBar 0x7f0f0078
+int style Base_Widget_AppCompat_ButtonBar_AlertDialog 0x7f0f0079
+int style Base_Widget_AppCompat_CompoundButton_CheckBox 0x7f0f007a
+int style Base_Widget_AppCompat_CompoundButton_RadioButton 0x7f0f007b
+int style Base_Widget_AppCompat_CompoundButton_Switch 0x7f0f007c
+int style Base_Widget_AppCompat_DrawerArrowToggle 0x7f0f007d
+int style Base_Widget_AppCompat_DrawerArrowToggle_Common 0x7f0f007e
+int style Base_Widget_AppCompat_DropDownItem_Spinner 0x7f0f007f
+int style Base_Widget_AppCompat_EditText 0x7f0f0080
+int style Base_Widget_AppCompat_ImageButton 0x7f0f0081
+int style Base_Widget_AppCompat_Light_ActionBar 0x7f0f0082
+int style Base_Widget_AppCompat_Light_ActionBar_Solid 0x7f0f0083
+int style Base_Widget_AppCompat_Light_ActionBar_TabBar 0x7f0f0084
+int style Base_Widget_AppCompat_Light_ActionBar_TabText 0x7f0f0085
+int style Base_Widget_AppCompat_Light_ActionBar_TabText_Inverse 0x7f0f0086
+int style Base_Widget_AppCompat_Light_ActionBar_TabView 0x7f0f0087
+int style Base_Widget_AppCompat_Light_PopupMenu 0x7f0f0088
+int style Base_Widget_AppCompat_Light_PopupMenu_Overflow 0x7f0f0089
+int style Base_Widget_AppCompat_ListMenuView 0x7f0f008a
+int style Base_Widget_AppCompat_ListPopupWindow 0x7f0f008b
+int style Base_Widget_AppCompat_ListView 0x7f0f008c
+int style Base_Widget_AppCompat_ListView_DropDown 0x7f0f008d
+int style Base_Widget_AppCompat_ListView_Menu 0x7f0f008e
+int style Base_Widget_AppCompat_PopupMenu 0x7f0f008f
+int style Base_Widget_AppCompat_PopupMenu_Overflow 0x7f0f0090
+int style Base_Widget_AppCompat_PopupWindow 0x7f0f0091
+int style Base_Widget_AppCompat_ProgressBar 0x7f0f0092
+int style Base_Widget_AppCompat_ProgressBar_Horizontal 0x7f0f0093
+int style Base_Widget_AppCompat_RatingBar 0x7f0f0094
+int style Base_Widget_AppCompat_RatingBar_Indicator 0x7f0f0095
+int style Base_Widget_AppCompat_RatingBar_Small 0x7f0f0096
+int style Base_Widget_AppCompat_SearchView 0x7f0f0097
+int style Base_Widget_AppCompat_SearchView_ActionBar 0x7f0f0098
+int style Base_Widget_AppCompat_SeekBar 0x7f0f0099
+int style Base_Widget_AppCompat_SeekBar_Discrete 0x7f0f009a
+int style Base_Widget_AppCompat_Spinner 0x7f0f009b
+int style Base_Widget_AppCompat_Spinner_Underlined 0x7f0f009c
+int style Base_Widget_AppCompat_TextView_SpinnerItem 0x7f0f009d
+int style Base_Widget_AppCompat_Toolbar 0x7f0f009e
+int style Base_Widget_AppCompat_Toolbar_Button_Navigation 0x7f0f009f
+int style HighlightTextAppearancePrimary 0x7f0f00a0
+int style HighlightTextAppearanceSecondary 0x7f0f00a1
+int style NoteActionBarStyle 0x7f0f00a2
+int style NoteTheme 0x7f0f00a3
+int style Platform_AppCompat 0x7f0f00a4
+int style Platform_AppCompat_Light 0x7f0f00a5
+int style Platform_ThemeOverlay_AppCompat 0x7f0f00a6
+int style Platform_ThemeOverlay_AppCompat_Dark 0x7f0f00a7
+int style Platform_ThemeOverlay_AppCompat_Light 0x7f0f00a8
+int style Platform_V21_AppCompat 0x7f0f00a9
+int style Platform_V21_AppCompat_Light 0x7f0f00aa
+int style Platform_V25_AppCompat 0x7f0f00ab
+int style Platform_V25_AppCompat_Light 0x7f0f00ac
+int style Platform_Widget_AppCompat_Spinner 0x7f0f00ad
+int style RtlOverlay_DialogWindowTitle_AppCompat 0x7f0f00ae
+int style RtlOverlay_Widget_AppCompat_ActionBar_TitleItem 0x7f0f00af
+int style RtlOverlay_Widget_AppCompat_DialogTitle_Icon 0x7f0f00b0
+int style RtlOverlay_Widget_AppCompat_PopupMenuItem 0x7f0f00b1
+int style RtlOverlay_Widget_AppCompat_PopupMenuItem_InternalGroup 0x7f0f00b2
+int style RtlOverlay_Widget_AppCompat_PopupMenuItem_Shortcut 0x7f0f00b3
+int style RtlOverlay_Widget_AppCompat_PopupMenuItem_SubmenuArrow 0x7f0f00b4
+int style RtlOverlay_Widget_AppCompat_PopupMenuItem_Text 0x7f0f00b5
+int style RtlOverlay_Widget_AppCompat_PopupMenuItem_Title 0x7f0f00b6
+int style RtlOverlay_Widget_AppCompat_Search_DropDown 0x7f0f00b7
+int style RtlOverlay_Widget_AppCompat_Search_DropDown_Icon1 0x7f0f00b8
+int style RtlOverlay_Widget_AppCompat_Search_DropDown_Icon2 0x7f0f00b9
+int style RtlOverlay_Widget_AppCompat_Search_DropDown_Query 0x7f0f00ba
+int style RtlOverlay_Widget_AppCompat_Search_DropDown_Text 0x7f0f00bb
+int style RtlOverlay_Widget_AppCompat_SearchView_MagIcon 0x7f0f00bc
+int style RtlUnderlay_Widget_AppCompat_ActionButton 0x7f0f00bd
+int style RtlUnderlay_Widget_AppCompat_ActionButton_Overflow 0x7f0f00be
+int style TextAppearance_AppCompat 0x7f0f00bf
+int style TextAppearance_AppCompat_Body1 0x7f0f00c0
+int style TextAppearance_AppCompat_Body2 0x7f0f00c1
+int style TextAppearance_AppCompat_Button 0x7f0f00c2
+int style TextAppearance_AppCompat_Caption 0x7f0f00c3
+int style TextAppearance_AppCompat_Display1 0x7f0f00c4
+int style TextAppearance_AppCompat_Display2 0x7f0f00c5
+int style TextAppearance_AppCompat_Display3 0x7f0f00c6
+int style TextAppearance_AppCompat_Display4 0x7f0f00c7
+int style TextAppearance_AppCompat_Headline 0x7f0f00c8
+int style TextAppearance_AppCompat_Inverse 0x7f0f00c9
+int style TextAppearance_AppCompat_Large 0x7f0f00ca
+int style TextAppearance_AppCompat_Large_Inverse 0x7f0f00cb
+int style TextAppearance_AppCompat_Light_SearchResult_Subtitle 0x7f0f00cc
+int style TextAppearance_AppCompat_Light_SearchResult_Title 0x7f0f00cd
+int style TextAppearance_AppCompat_Light_Widget_PopupMenu_Large 0x7f0f00ce
+int style TextAppearance_AppCompat_Light_Widget_PopupMenu_Small 0x7f0f00cf
+int style TextAppearance_AppCompat_Medium 0x7f0f00d0
+int style TextAppearance_AppCompat_Medium_Inverse 0x7f0f00d1
+int style TextAppearance_AppCompat_Menu 0x7f0f00d2
+int style TextAppearance_AppCompat_SearchResult_Subtitle 0x7f0f00d3
+int style TextAppearance_AppCompat_SearchResult_Title 0x7f0f00d4
+int style TextAppearance_AppCompat_Small 0x7f0f00d5
+int style TextAppearance_AppCompat_Small_Inverse 0x7f0f00d6
+int style TextAppearance_AppCompat_Subhead 0x7f0f00d7
+int style TextAppearance_AppCompat_Subhead_Inverse 0x7f0f00d8
+int style TextAppearance_AppCompat_Title 0x7f0f00d9
+int style TextAppearance_AppCompat_Title_Inverse 0x7f0f00da
+int style TextAppearance_AppCompat_Tooltip 0x7f0f00db
+int style TextAppearance_AppCompat_Widget_ActionBar_Menu 0x7f0f00dc
+int style TextAppearance_AppCompat_Widget_ActionBar_Subtitle 0x7f0f00dd
+int style TextAppearance_AppCompat_Widget_ActionBar_Subtitle_Inverse 0x7f0f00de
+int style TextAppearance_AppCompat_Widget_ActionBar_Title 0x7f0f00df
+int style TextAppearance_AppCompat_Widget_ActionBar_Title_Inverse 0x7f0f00e0
+int style TextAppearance_AppCompat_Widget_ActionMode_Subtitle 0x7f0f00e1
+int style TextAppearance_AppCompat_Widget_ActionMode_Subtitle_Inverse 0x7f0f00e2
+int style TextAppearance_AppCompat_Widget_ActionMode_Title 0x7f0f00e3
+int style TextAppearance_AppCompat_Widget_ActionMode_Title_Inverse 0x7f0f00e4
+int style TextAppearance_AppCompat_Widget_Button 0x7f0f00e5
+int style TextAppearance_AppCompat_Widget_Button_Borderless_Colored 0x7f0f00e6
+int style TextAppearance_AppCompat_Widget_Button_Colored 0x7f0f00e7
+int style TextAppearance_AppCompat_Widget_Button_Inverse 0x7f0f00e8
+int style TextAppearance_AppCompat_Widget_DropDownItem 0x7f0f00e9
+int style TextAppearance_AppCompat_Widget_PopupMenu_Header 0x7f0f00ea
+int style TextAppearance_AppCompat_Widget_PopupMenu_Large 0x7f0f00eb
+int style TextAppearance_AppCompat_Widget_PopupMenu_Small 0x7f0f00ec
+int style TextAppearance_AppCompat_Widget_Switch 0x7f0f00ed
+int style TextAppearance_AppCompat_Widget_TextView_SpinnerItem 0x7f0f00ee
+int style TextAppearance_Compat_Notification 0x7f0f00ef
+int style TextAppearance_Compat_Notification_Info 0x7f0f00f0
+int style TextAppearance_Compat_Notification_Info_Media 0x7f0f00f1
+int style TextAppearance_Compat_Notification_Line2 0x7f0f00f2
+int style TextAppearance_Compat_Notification_Line2_Media 0x7f0f00f3
+int style TextAppearance_Compat_Notification_Media 0x7f0f00f4
+int style TextAppearance_Compat_Notification_Time 0x7f0f00f5
+int style TextAppearance_Compat_Notification_Time_Media 0x7f0f00f6
+int style TextAppearance_Compat_Notification_Title 0x7f0f00f7
+int style TextAppearance_Compat_Notification_Title_Media 0x7f0f00f8
+int style TextAppearance_Widget_AppCompat_ExpandedMenu_Item 0x7f0f00f9
+int style TextAppearance_Widget_AppCompat_Toolbar_Subtitle 0x7f0f00fa
+int style TextAppearance_Widget_AppCompat_Toolbar_Title 0x7f0f00fb
+int style TextAppearanceLarge 0x7f0f00fc
+int style TextAppearanceMedium 0x7f0f00fd
+int style TextAppearanceNormal 0x7f0f00fe
+int style TextAppearancePrimaryItem 0x7f0f00ff
+int style TextAppearanceSecondaryItem 0x7f0f0100
+int style TextAppearanceSuper 0x7f0f0101
+int style TextAppearanceUnderMenuIcon 0x7f0f0102
+int style Theme_AppCompat 0x7f0f0103
+int style Theme_AppCompat_CompactMenu 0x7f0f0104
+int style Theme_AppCompat_DayNight 0x7f0f0105
+int style Theme_AppCompat_DayNight_DarkActionBar 0x7f0f0106
+int style Theme_AppCompat_DayNight_Dialog 0x7f0f0107
+int style Theme_AppCompat_DayNight_Dialog_Alert 0x7f0f0108
+int style Theme_AppCompat_DayNight_Dialog_MinWidth 0x7f0f0109
+int style Theme_AppCompat_DayNight_DialogWhenLarge 0x7f0f010a
+int style Theme_AppCompat_DayNight_NoActionBar 0x7f0f010b
+int style Theme_AppCompat_Dialog 0x7f0f010c
+int style Theme_AppCompat_Dialog_Alert 0x7f0f010d
+int style Theme_AppCompat_Dialog_MinWidth 0x7f0f010e
+int style Theme_AppCompat_DialogWhenLarge 0x7f0f010f
+int style Theme_AppCompat_Light 0x7f0f0110
+int style Theme_AppCompat_Light_DarkActionBar 0x7f0f0111
+int style Theme_AppCompat_Light_Dialog 0x7f0f0112
+int style Theme_AppCompat_Light_Dialog_Alert 0x7f0f0113
+int style Theme_AppCompat_Light_Dialog_MinWidth 0x7f0f0114
+int style Theme_AppCompat_Light_DialogWhenLarge 0x7f0f0115
+int style Theme_AppCompat_Light_NoActionBar 0x7f0f0116
+int style Theme_AppCompat_NoActionBar 0x7f0f0117
+int style ThemeOverlay_AppCompat 0x7f0f0118
+int style ThemeOverlay_AppCompat_ActionBar 0x7f0f0119
+int style ThemeOverlay_AppCompat_Dark 0x7f0f011a
+int style ThemeOverlay_AppCompat_Dark_ActionBar 0x7f0f011b
+int style ThemeOverlay_AppCompat_Dialog 0x7f0f011c
+int style ThemeOverlay_AppCompat_Dialog_Alert 0x7f0f011d
+int style ThemeOverlay_AppCompat_Light 0x7f0f011e
+int style Widget_AppCompat_ActionBar 0x7f0f011f
+int style Widget_AppCompat_ActionBar_Solid 0x7f0f0120
+int style Widget_AppCompat_ActionBar_TabBar 0x7f0f0121
+int style Widget_AppCompat_ActionBar_TabText 0x7f0f0122
+int style Widget_AppCompat_ActionBar_TabView 0x7f0f0123
+int style Widget_AppCompat_ActionButton 0x7f0f0124
+int style Widget_AppCompat_ActionButton_CloseMode 0x7f0f0125
+int style Widget_AppCompat_ActionButton_Overflow 0x7f0f0126
+int style Widget_AppCompat_ActionMode 0x7f0f0127
+int style Widget_AppCompat_ActivityChooserView 0x7f0f0128
+int style Widget_AppCompat_AutoCompleteTextView 0x7f0f0129
+int style Widget_AppCompat_Button 0x7f0f012a
+int style Widget_AppCompat_Button_Borderless 0x7f0f012b
+int style Widget_AppCompat_Button_Borderless_Colored 0x7f0f012c
+int style Widget_AppCompat_Button_ButtonBar_AlertDialog 0x7f0f012d
+int style Widget_AppCompat_Button_Colored 0x7f0f012e
+int style Widget_AppCompat_Button_Small 0x7f0f012f
+int style Widget_AppCompat_ButtonBar 0x7f0f0130
+int style Widget_AppCompat_ButtonBar_AlertDialog 0x7f0f0131
+int style Widget_AppCompat_CompoundButton_CheckBox 0x7f0f0132
+int style Widget_AppCompat_CompoundButton_RadioButton 0x7f0f0133
+int style Widget_AppCompat_CompoundButton_Switch 0x7f0f0134
+int style Widget_AppCompat_DrawerArrowToggle 0x7f0f0135
+int style Widget_AppCompat_DropDownItem_Spinner 0x7f0f0136
+int style Widget_AppCompat_EditText 0x7f0f0137
+int style Widget_AppCompat_ImageButton 0x7f0f0138
+int style Widget_AppCompat_Light_ActionBar 0x7f0f0139
+int style Widget_AppCompat_Light_ActionBar_Solid 0x7f0f013a
+int style Widget_AppCompat_Light_ActionBar_Solid_Inverse 0x7f0f013b
+int style Widget_AppCompat_Light_ActionBar_TabBar 0x7f0f013c
+int style Widget_AppCompat_Light_ActionBar_TabBar_Inverse 0x7f0f013d
+int style Widget_AppCompat_Light_ActionBar_TabText 0x7f0f013e
+int style Widget_AppCompat_Light_ActionBar_TabText_Inverse 0x7f0f013f
+int style Widget_AppCompat_Light_ActionBar_TabView 0x7f0f0140
+int style Widget_AppCompat_Light_ActionBar_TabView_Inverse 0x7f0f0141
+int style Widget_AppCompat_Light_ActionButton 0x7f0f0142
+int style Widget_AppCompat_Light_ActionButton_CloseMode 0x7f0f0143
+int style Widget_AppCompat_Light_ActionButton_Overflow 0x7f0f0144
+int style Widget_AppCompat_Light_ActionMode_Inverse 0x7f0f0145
+int style Widget_AppCompat_Light_ActivityChooserView 0x7f0f0146
+int style Widget_AppCompat_Light_AutoCompleteTextView 0x7f0f0147
+int style Widget_AppCompat_Light_DropDownItem_Spinner 0x7f0f0148
+int style Widget_AppCompat_Light_ListPopupWindow 0x7f0f0149
+int style Widget_AppCompat_Light_ListView_DropDown 0x7f0f014a
+int style Widget_AppCompat_Light_PopupMenu 0x7f0f014b
+int style Widget_AppCompat_Light_PopupMenu_Overflow 0x7f0f014c
+int style Widget_AppCompat_Light_SearchView 0x7f0f014d
+int style Widget_AppCompat_Light_Spinner_DropDown_ActionBar 0x7f0f014e
+int style Widget_AppCompat_ListMenuView 0x7f0f014f
+int style Widget_AppCompat_ListPopupWindow 0x7f0f0150
+int style Widget_AppCompat_ListView 0x7f0f0151
+int style Widget_AppCompat_ListView_DropDown 0x7f0f0152
+int style Widget_AppCompat_ListView_Menu 0x7f0f0153
+int style Widget_AppCompat_PopupMenu 0x7f0f0154
+int style Widget_AppCompat_PopupMenu_Overflow 0x7f0f0155
+int style Widget_AppCompat_PopupWindow 0x7f0f0156
+int style Widget_AppCompat_ProgressBar 0x7f0f0157
+int style Widget_AppCompat_ProgressBar_Horizontal 0x7f0f0158
+int style Widget_AppCompat_RatingBar 0x7f0f0159
+int style Widget_AppCompat_RatingBar_Indicator 0x7f0f015a
+int style Widget_AppCompat_RatingBar_Small 0x7f0f015b
+int style Widget_AppCompat_SearchView 0x7f0f015c
+int style Widget_AppCompat_SearchView_ActionBar 0x7f0f015d
+int style Widget_AppCompat_SeekBar 0x7f0f015e
+int style Widget_AppCompat_SeekBar_Discrete 0x7f0f015f
+int style Widget_AppCompat_Spinner 0x7f0f0160
+int style Widget_AppCompat_Spinner_DropDown 0x7f0f0161
+int style Widget_AppCompat_Spinner_DropDown_ActionBar 0x7f0f0162
+int style Widget_AppCompat_Spinner_Underlined 0x7f0f0163
+int style Widget_AppCompat_TextView_SpinnerItem 0x7f0f0164
+int style Widget_AppCompat_Toolbar 0x7f0f0165
+int style Widget_AppCompat_Toolbar_Button_Navigation 0x7f0f0166
+int style Widget_Compat_NotificationActionContainer 0x7f0f0167
+int style Widget_Compat_NotificationActionText 0x7f0f0168
+int style Widget_Support_CoordinatorLayout 0x7f0f0169
+int[] styleable ActionBar { 0x7f030031, 0x7f030032, 0x7f030033, 0x7f030057, 0x7f030058, 0x7f030059, 0x7f03005a, 0x7f03005b, 0x7f03005c, 0x7f03005f, 0x7f030064, 0x7f030065, 0x7f030070, 0x7f030080, 0x7f030081, 0x7f030082, 0x7f030083, 0x7f030084, 0x7f030089, 0x7f03008c, 0x7f0300a2, 0x7f0300a9, 0x7f0300b4, 0x7f0300b7, 0x7f0300b8, 0x7f0300d3, 0x7f0300d6, 0x7f0300f1, 0x7f0300fa }
+int styleable ActionBar_background 0
+int styleable ActionBar_backgroundSplit 1
+int styleable ActionBar_backgroundStacked 2
+int styleable ActionBar_contentInsetEnd 3
+int styleable ActionBar_contentInsetEndWithActions 4
+int styleable ActionBar_contentInsetLeft 5
+int styleable ActionBar_contentInsetRight 6
+int styleable ActionBar_contentInsetStart 7
+int styleable ActionBar_contentInsetStartWithNavigation 8
+int styleable ActionBar_customNavigationLayout 9
+int styleable ActionBar_displayOptions 10
+int styleable ActionBar_divider 11
+int styleable ActionBar_elevation 12
+int styleable ActionBar_height 13
+int styleable ActionBar_hideOnContentScroll 14
+int styleable ActionBar_homeAsUpIndicator 15
+int styleable ActionBar_homeLayout 16
+int styleable ActionBar_icon 17
+int styleable ActionBar_indeterminateProgressStyle 18
+int styleable ActionBar_itemPadding 19
+int styleable ActionBar_logo 20
+int styleable ActionBar_navigationMode 21
+int styleable ActionBar_popupTheme 22
+int styleable ActionBar_progressBarPadding 23
+int styleable ActionBar_progressBarStyle 24
+int styleable ActionBar_subtitle 25
+int styleable ActionBar_subtitleTextStyle 26
+int styleable ActionBar_title 27
+int styleable ActionBar_titleTextStyle 28
+int[] styleable ActionBarLayout { 0x010100b3 }
+int styleable ActionBarLayout_android_layout_gravity 0
+int[] styleable ActionMenuItemView { 0x0101013f }
+int styleable ActionMenuItemView_android_minWidth 0
+int[] styleable ActionMenuView { }
+int[] styleable ActionMode { 0x7f030031, 0x7f030032, 0x7f030047, 0x7f030080, 0x7f0300d6, 0x7f0300fa }
+int styleable ActionMode_background 0
+int styleable ActionMode_backgroundSplit 1
+int styleable ActionMode_closeItemLayout 2
+int styleable ActionMode_height 3
+int styleable ActionMode_subtitleTextStyle 4
+int styleable ActionMode_titleTextStyle 5
+int[] styleable ActivityChooserView { 0x7f030071, 0x7f03008a }
+int styleable ActivityChooserView_expandActivityOverflowButtonDrawable 0
+int styleable ActivityChooserView_initialActivityCount 1
+int[] styleable AlertDialog { 0x010100f2, 0x7f03003e, 0x7f03003f, 0x7f030099, 0x7f03009a, 0x7f0300a6, 0x7f0300c8, 0x7f0300c9 }
+int styleable AlertDialog_android_layout 0
+int styleable AlertDialog_buttonIconDimen 1
+int styleable AlertDialog_buttonPanelSideLayout 2
+int styleable AlertDialog_listItemLayout 3
+int styleable AlertDialog_listLayout 4
+int styleable AlertDialog_multiChoiceItemLayout 5
+int styleable AlertDialog_showTitle 6
+int styleable AlertDialog_singleChoiceItemLayout 7
+int[] styleable AppCompatImageView { 0x01010119, 0x7f0300ce, 0x7f0300ef, 0x7f0300f0 }
+int styleable AppCompatImageView_android_src 0
+int styleable AppCompatImageView_srcCompat 1
+int styleable AppCompatImageView_tint 2
+int styleable AppCompatImageView_tintMode 3
+int[] styleable AppCompatSeekBar { 0x01010142, 0x7f0300ec, 0x7f0300ed, 0x7f0300ee }
+int styleable AppCompatSeekBar_android_thumb 0
+int styleable AppCompatSeekBar_tickMark 1
+int styleable AppCompatSeekBar_tickMarkTint 2
+int styleable AppCompatSeekBar_tickMarkTintMode 3
+int[] styleable AppCompatTextHelper { 0x01010034, 0x0101016d, 0x0101016e, 0x0101016f, 0x01010170, 0x01010392, 0x01010393 }
+int styleable AppCompatTextHelper_android_textAppearance 0
+int styleable AppCompatTextHelper_android_drawableTop 1
+int styleable AppCompatTextHelper_android_drawableBottom 2
+int styleable AppCompatTextHelper_android_drawableLeft 3
+int styleable AppCompatTextHelper_android_drawableRight 4
+int styleable AppCompatTextHelper_android_drawableStart 5
+int styleable AppCompatTextHelper_android_drawableEnd 6
+int[] styleable AppCompatTextView { 0x01010034, 0x7f03002c, 0x7f03002d, 0x7f03002e, 0x7f03002f, 0x7f030030, 0x7f030072, 0x7f030074, 0x7f03008e, 0x7f030096, 0x7f0300dc }
+int styleable AppCompatTextView_android_textAppearance 0
+int styleable AppCompatTextView_autoSizeMaxTextSize 1
+int styleable AppCompatTextView_autoSizeMinTextSize 2
+int styleable AppCompatTextView_autoSizePresetSizes 3
+int styleable AppCompatTextView_autoSizeStepGranularity 4
+int styleable AppCompatTextView_autoSizeTextType 5
+int styleable AppCompatTextView_firstBaselineToTopHeight 6
+int styleable AppCompatTextView_fontFamily 7
+int styleable AppCompatTextView_lastBaselineToBottomHeight 8
+int styleable AppCompatTextView_lineHeight 9
+int styleable AppCompatTextView_textAllCaps 10
+int[] styleable AppCompatTheme { 0x01010057, 0x010100ae, 0x7f030000, 0x7f030001, 0x7f030002, 0x7f030003, 0x7f030004, 0x7f030005, 0x7f030006, 0x7f030007, 0x7f030008, 0x7f030009, 0x7f03000a, 0x7f03000b, 0x7f03000c, 0x7f03000e, 0x7f03000f, 0x7f030010, 0x7f030011, 0x7f030012, 0x7f030013, 0x7f030014, 0x7f030015, 0x7f030016, 0x7f030017, 0x7f030018, 0x7f030019, 0x7f03001a, 0x7f03001b, 0x7f03001c, 0x7f03001d, 0x7f03001e, 0x7f030021, 0x7f030022, 0x7f030023, 0x7f030024, 0x7f030025, 0x7f03002b, 0x7f030037, 0x7f030038, 0x7f030039, 0x7f03003a, 0x7f03003b, 0x7f03003c, 0x7f030040, 0x7f030041, 0x7f030044, 0x7f030045, 0x7f03004b, 0x7f03004c, 0x7f03004d, 0x7f03004e, 0x7f03004f, 0x7f030050, 0x7f030051, 0x7f030052, 0x7f030053, 0x7f030054, 0x7f03005d, 0x7f030061, 0x7f030062, 0x7f030063, 0x7f030066, 0x7f030068, 0x7f03006b, 0x7f03006c, 0x7f03006d, 0x7f03006e, 0x7f03006f, 0x7f030082, 0x7f030088, 0x7f030097, 0x7f030098, 0x7f03009b, 0x7f03009c, 0x7f03009d, 0x7f03009e, 0x7f03009f, 0x7f0300a0, 0x7f0300a1, 0x7f0300b0, 0x7f0300b1, 0x7f0300b2, 0x7f0300b3, 0x7f0300b5, 0x7f0300bb, 0x7f0300bc, 0x7f0300bd, 0x7f0300be, 0x7f0300c1, 0x7f0300c2, 0x7f0300c3, 0x7f0300c4, 0x7f0300cb, 0x7f0300cc, 0x7f0300da, 0x7f0300dd, 0x7f0300de, 0x7f0300df, 0x7f0300e0, 0x7f0300e1, 0x7f0300e2, 0x7f0300e3, 0x7f0300e4, 0x7f0300e5, 0x7f0300e6, 0x7f0300fb, 0x7f0300fc, 0x7f0300fd, 0x7f0300fe, 0x7f030104, 0x7f030106, 0x7f030107, 0x7f030108, 0x7f030109, 0x7f03010a, 0x7f03010b, 0x7f03010c, 0x7f03010d, 0x7f03010e, 0x7f03010f }
+int styleable AppCompatTheme_android_windowIsFloating 0
+int styleable AppCompatTheme_android_windowAnimationStyle 1
+int styleable AppCompatTheme_actionBarDivider 2
+int styleable AppCompatTheme_actionBarItemBackground 3
+int styleable AppCompatTheme_actionBarPopupTheme 4
+int styleable AppCompatTheme_actionBarSize 5
+int styleable AppCompatTheme_actionBarSplitStyle 6
+int styleable AppCompatTheme_actionBarStyle 7
+int styleable AppCompatTheme_actionBarTabBarStyle 8
+int styleable AppCompatTheme_actionBarTabStyle 9
+int styleable AppCompatTheme_actionBarTabTextStyle 10
+int styleable AppCompatTheme_actionBarTheme 11
+int styleable AppCompatTheme_actionBarWidgetTheme 12
+int styleable AppCompatTheme_actionButtonStyle 13
+int styleable AppCompatTheme_actionDropDownStyle 14
+int styleable AppCompatTheme_actionMenuTextAppearance 15
+int styleable AppCompatTheme_actionMenuTextColor 16
+int styleable AppCompatTheme_actionModeBackground 17
+int styleable AppCompatTheme_actionModeCloseButtonStyle 18
+int styleable AppCompatTheme_actionModeCloseDrawable 19
+int styleable AppCompatTheme_actionModeCopyDrawable 20
+int styleable AppCompatTheme_actionModeCutDrawable 21
+int styleable AppCompatTheme_actionModeFindDrawable 22
+int styleable AppCompatTheme_actionModePasteDrawable 23
+int styleable AppCompatTheme_actionModePopupWindowStyle 24
+int styleable AppCompatTheme_actionModeSelectAllDrawable 25
+int styleable AppCompatTheme_actionModeShareDrawable 26
+int styleable AppCompatTheme_actionModeSplitBackground 27
+int styleable AppCompatTheme_actionModeStyle 28
+int styleable AppCompatTheme_actionModeWebSearchDrawable 29
+int styleable AppCompatTheme_actionOverflowButtonStyle 30
+int styleable AppCompatTheme_actionOverflowMenuStyle 31
+int styleable AppCompatTheme_activityChooserViewStyle 32
+int styleable AppCompatTheme_alertDialogButtonGroupStyle 33
+int styleable AppCompatTheme_alertDialogCenterButtons 34
+int styleable AppCompatTheme_alertDialogStyle 35
+int styleable AppCompatTheme_alertDialogTheme 36
+int styleable AppCompatTheme_autoCompleteTextViewStyle 37
+int styleable AppCompatTheme_borderlessButtonStyle 38
+int styleable AppCompatTheme_buttonBarButtonStyle 39
+int styleable AppCompatTheme_buttonBarNegativeButtonStyle 40
+int styleable AppCompatTheme_buttonBarNeutralButtonStyle 41
+int styleable AppCompatTheme_buttonBarPositiveButtonStyle 42
+int styleable AppCompatTheme_buttonBarStyle 43
+int styleable AppCompatTheme_buttonStyle 44
+int styleable AppCompatTheme_buttonStyleSmall 45
+int styleable AppCompatTheme_checkboxStyle 46
+int styleable AppCompatTheme_checkedTextViewStyle 47
+int styleable AppCompatTheme_colorAccent 48
+int styleable AppCompatTheme_colorBackgroundFloating 49
+int styleable AppCompatTheme_colorButtonNormal 50
+int styleable AppCompatTheme_colorControlActivated 51
+int styleable AppCompatTheme_colorControlHighlight 52
+int styleable AppCompatTheme_colorControlNormal 53
+int styleable AppCompatTheme_colorError 54
+int styleable AppCompatTheme_colorPrimary 55
+int styleable AppCompatTheme_colorPrimaryDark 56
+int styleable AppCompatTheme_colorSwitchThumbNormal 57
+int styleable AppCompatTheme_controlBackground 58
+int styleable AppCompatTheme_dialogCornerRadius 59
+int styleable AppCompatTheme_dialogPreferredPadding 60
+int styleable AppCompatTheme_dialogTheme 61
+int styleable AppCompatTheme_dividerHorizontal 62
+int styleable AppCompatTheme_dividerVertical 63
+int styleable AppCompatTheme_dropDownListViewStyle 64
+int styleable AppCompatTheme_dropdownListPreferredItemHeight 65
+int styleable AppCompatTheme_editTextBackground 66
+int styleable AppCompatTheme_editTextColor 67
+int styleable AppCompatTheme_editTextStyle 68
+int styleable AppCompatTheme_homeAsUpIndicator 69
+int styleable AppCompatTheme_imageButtonStyle 70
+int styleable AppCompatTheme_listChoiceBackgroundIndicator 71
+int styleable AppCompatTheme_listDividerAlertDialog 72
+int styleable AppCompatTheme_listMenuViewStyle 73
+int styleable AppCompatTheme_listPopupWindowStyle 74
+int styleable AppCompatTheme_listPreferredItemHeight 75
+int styleable AppCompatTheme_listPreferredItemHeightLarge 76
+int styleable AppCompatTheme_listPreferredItemHeightSmall 77
+int styleable AppCompatTheme_listPreferredItemPaddingLeft 78
+int styleable AppCompatTheme_listPreferredItemPaddingRight 79
+int styleable AppCompatTheme_panelBackground 80
+int styleable AppCompatTheme_panelMenuListTheme 81
+int styleable AppCompatTheme_panelMenuListWidth 82
+int styleable AppCompatTheme_popupMenuStyle 83
+int styleable AppCompatTheme_popupWindowStyle 84
+int styleable AppCompatTheme_radioButtonStyle 85
+int styleable AppCompatTheme_ratingBarStyle 86
+int styleable AppCompatTheme_ratingBarStyleIndicator 87
+int styleable AppCompatTheme_ratingBarStyleSmall 88
+int styleable AppCompatTheme_searchViewStyle 89
+int styleable AppCompatTheme_seekBarStyle 90
+int styleable AppCompatTheme_selectableItemBackground 91
+int styleable AppCompatTheme_selectableItemBackgroundBorderless 92
+int styleable AppCompatTheme_spinnerDropDownItemStyle 93
+int styleable AppCompatTheme_spinnerStyle 94
+int styleable AppCompatTheme_switchStyle 95
+int styleable AppCompatTheme_textAppearanceLargePopupMenu 96
+int styleable AppCompatTheme_textAppearanceListItem 97
+int styleable AppCompatTheme_textAppearanceListItemSecondary 98
+int styleable AppCompatTheme_textAppearanceListItemSmall 99
+int styleable AppCompatTheme_textAppearancePopupMenuHeader 100
+int styleable AppCompatTheme_textAppearanceSearchResultSubtitle 101
+int styleable AppCompatTheme_textAppearanceSearchResultTitle 102
+int styleable AppCompatTheme_textAppearanceSmallPopupMenu 103
+int styleable AppCompatTheme_textColorAlertDialogListItem 104
+int styleable AppCompatTheme_textColorSearchUrl 105
+int styleable AppCompatTheme_toolbarNavigationButtonStyle 106
+int styleable AppCompatTheme_toolbarStyle 107
+int styleable AppCompatTheme_tooltipForegroundColor 108
+int styleable AppCompatTheme_tooltipFrameBackground 109
+int styleable AppCompatTheme_viewInflaterClass 110
+int styleable AppCompatTheme_windowActionBar 111
+int styleable AppCompatTheme_windowActionBarOverlay 112
+int styleable AppCompatTheme_windowActionModeOverlay 113
+int styleable AppCompatTheme_windowFixedHeightMajor 114
+int styleable AppCompatTheme_windowFixedHeightMinor 115
+int styleable AppCompatTheme_windowFixedWidthMajor 116
+int styleable AppCompatTheme_windowFixedWidthMinor 117
+int styleable AppCompatTheme_windowMinWidthMajor 118
+int styleable AppCompatTheme_windowMinWidthMinor 119
+int styleable AppCompatTheme_windowNoTitle 120
+int[] styleable ButtonBarLayout { 0x7f030026 }
+int styleable ButtonBarLayout_allowStacking 0
+int[] styleable ColorStateListItem { 0x010101a5, 0x0101031f, 0x7f030027 }
+int styleable ColorStateListItem_android_color 0
+int styleable ColorStateListItem_android_alpha 1
+int styleable ColorStateListItem_alpha 2
+int[] styleable CompoundButton { 0x01010107, 0x7f030042, 0x7f030043 }
+int styleable CompoundButton_android_button 0
+int styleable CompoundButton_buttonTint 1
+int styleable CompoundButton_buttonTintMode 2
+int[] styleable CoordinatorLayout { 0x7f03008d, 0x7f0300d0 }
+int styleable CoordinatorLayout_keylines 0
+int styleable CoordinatorLayout_statusBarBackground 1
+int[] styleable CoordinatorLayout_Layout { 0x010100b3, 0x7f030090, 0x7f030091, 0x7f030092, 0x7f030093, 0x7f030094, 0x7f030095 }
+int styleable CoordinatorLayout_Layout_android_layout_gravity 0
+int styleable CoordinatorLayout_Layout_layout_anchor 1
+int styleable CoordinatorLayout_Layout_layout_anchorGravity 2
+int styleable CoordinatorLayout_Layout_layout_behavior 3
+int styleable CoordinatorLayout_Layout_layout_dodgeInsetEdges 4
+int styleable CoordinatorLayout_Layout_layout_insetEdge 5
+int styleable CoordinatorLayout_Layout_layout_keyline 6
+int[] styleable DrawerArrowToggle { 0x7f030029, 0x7f03002a, 0x7f030036, 0x7f03004a, 0x7f030069, 0x7f03007e, 0x7f0300ca, 0x7f0300e8 }
+int styleable DrawerArrowToggle_arrowHeadLength 0
+int styleable DrawerArrowToggle_arrowShaftLength 1
+int styleable DrawerArrowToggle_barLength 2
+int styleable DrawerArrowToggle_color 3
+int styleable DrawerArrowToggle_drawableSize 4
+int styleable DrawerArrowToggle_gapBetweenBars 5
+int styleable DrawerArrowToggle_spinBars 6
+int styleable DrawerArrowToggle_thickness 7
+int[] styleable FontFamily { 0x7f030075, 0x7f030076, 0x7f030077, 0x7f030078, 0x7f030079, 0x7f03007a }
+int styleable FontFamily_fontProviderAuthority 0
+int styleable FontFamily_fontProviderCerts 1
+int styleable FontFamily_fontProviderFetchStrategy 2
+int styleable FontFamily_fontProviderFetchTimeout 3
+int styleable FontFamily_fontProviderPackage 4
+int styleable FontFamily_fontProviderQuery 5
+int[] styleable FontFamilyFont { 0x01010532, 0x01010533, 0x0101053f, 0x0101056f, 0x01010570, 0x7f030073, 0x7f03007b, 0x7f03007c, 0x7f03007d, 0x7f030103 }
+int styleable FontFamilyFont_android_font 0
+int styleable FontFamilyFont_android_fontWeight 1
+int styleable FontFamilyFont_android_fontStyle 2
+int styleable FontFamilyFont_android_ttcIndex 3
+int styleable FontFamilyFont_android_fontVariationSettings 4
+int styleable FontFamilyFont_font 5
+int styleable FontFamilyFont_fontStyle 6
+int styleable FontFamilyFont_fontVariationSettings 7
+int styleable FontFamilyFont_fontWeight 8
+int styleable FontFamilyFont_ttcIndex 9
+int[] styleable GradientColor { 0x0101019d, 0x0101019e, 0x010101a1, 0x010101a2, 0x010101a3, 0x010101a4, 0x01010201, 0x0101020b, 0x01010510, 0x01010511, 0x01010512, 0x01010513 }
+int styleable GradientColor_android_startColor 0
+int styleable GradientColor_android_endColor 1
+int styleable GradientColor_android_type 2
+int styleable GradientColor_android_centerX 3
+int styleable GradientColor_android_centerY 4
+int styleable GradientColor_android_gradientRadius 5
+int styleable GradientColor_android_tileMode 6
+int styleable GradientColor_android_centerColor 7
+int styleable GradientColor_android_startX 8
+int styleable GradientColor_android_startY 9
+int styleable GradientColor_android_endX 10
+int styleable GradientColor_android_endY 11
+int[] styleable GradientColorItem { 0x010101a5, 0x01010514 }
+int styleable GradientColorItem_android_color 0
+int styleable GradientColorItem_android_offset 1
+int[] styleable LinearLayoutCompat { 0x010100af, 0x010100c4, 0x01010126, 0x01010127, 0x01010128, 0x7f030065, 0x7f030067, 0x7f0300a5, 0x7f0300c6 }
+int styleable LinearLayoutCompat_android_gravity 0
+int styleable LinearLayoutCompat_android_orientation 1
+int styleable LinearLayoutCompat_android_baselineAligned 2
+int styleable LinearLayoutCompat_android_baselineAlignedChildIndex 3
+int styleable LinearLayoutCompat_android_weightSum 4
+int styleable LinearLayoutCompat_divider 5
+int styleable LinearLayoutCompat_dividerPadding 6
+int styleable LinearLayoutCompat_measureWithLargestChild 7
+int styleable LinearLayoutCompat_showDividers 8
+int[] styleable LinearLayoutCompat_Layout { 0x010100b3, 0x010100f4, 0x010100f5, 0x01010181 }
+int styleable LinearLayoutCompat_Layout_android_layout_gravity 0
+int styleable LinearLayoutCompat_Layout_android_layout_width 1
+int styleable LinearLayoutCompat_Layout_android_layout_height 2
+int styleable LinearLayoutCompat_Layout_android_layout_weight 3
+int[] styleable ListPopupWindow { 0x010102ac, 0x010102ad }
+int styleable ListPopupWindow_android_dropDownHorizontalOffset 0
+int styleable ListPopupWindow_android_dropDownVerticalOffset 1
+int[] styleable MenuGroup { 0x0101000e, 0x010100d0, 0x01010194, 0x010101de, 0x010101df, 0x010101e0 }
+int styleable MenuGroup_android_enabled 0
+int styleable MenuGroup_android_id 1
+int styleable MenuGroup_android_visible 2
+int styleable MenuGroup_android_menuCategory 3
+int styleable MenuGroup_android_orderInCategory 4
+int styleable MenuGroup_android_checkableBehavior 5
+int[] styleable MenuItem { 0x01010002, 0x0101000e, 0x010100d0, 0x01010106, 0x01010194, 0x010101de, 0x010101df, 0x010101e1, 0x010101e2, 0x010101e3, 0x010101e4, 0x010101e5, 0x0101026f, 0x7f03000d, 0x7f03001f, 0x7f030020, 0x7f030028, 0x7f030056, 0x7f030085, 0x7f030086, 0x7f0300aa, 0x7f0300c5, 0x7f0300ff }
+int styleable MenuItem_android_icon 0
+int styleable MenuItem_android_enabled 1
+int styleable MenuItem_android_id 2
+int styleable MenuItem_android_checked 3
+int styleable MenuItem_android_visible 4
+int styleable MenuItem_android_menuCategory 5
+int styleable MenuItem_android_orderInCategory 6
+int styleable MenuItem_android_title 7
+int styleable MenuItem_android_titleCondensed 8
+int styleable MenuItem_android_alphabeticShortcut 9
+int styleable MenuItem_android_numericShortcut 10
+int styleable MenuItem_android_checkable 11
+int styleable MenuItem_android_onClick 12
+int styleable MenuItem_actionLayout 13
+int styleable MenuItem_actionProviderClass 14
+int styleable MenuItem_actionViewClass 15
+int styleable MenuItem_alphabeticModifiers 16
+int styleable MenuItem_contentDescription 17
+int styleable MenuItem_iconTint 18
+int styleable MenuItem_iconTintMode 19
+int styleable MenuItem_numericModifiers 20
+int styleable MenuItem_showAsAction 21
+int styleable MenuItem_tooltipText 22
+int[] styleable MenuView { 0x010100ae, 0x0101012c, 0x0101012d, 0x0101012e, 0x0101012f, 0x01010130, 0x01010131, 0x7f0300b6, 0x7f0300d1 }
+int styleable MenuView_android_windowAnimationStyle 0
+int styleable MenuView_android_itemTextAppearance 1
+int styleable MenuView_android_horizontalDivider 2
+int styleable MenuView_android_verticalDivider 3
+int styleable MenuView_android_headerBackground 4
+int styleable MenuView_android_itemBackground 5
+int styleable MenuView_android_itemIconDisabledAlpha 6
+int styleable MenuView_preserveIconSpacing 7
+int styleable MenuView_subMenuArrow 8
+int[] styleable PopupWindow { 0x01010176, 0x010102c9, 0x7f0300ab }
+int styleable PopupWindow_android_popupBackground 0
+int styleable PopupWindow_android_popupAnimationStyle 1
+int styleable PopupWindow_overlapAnchor 2
+int[] styleable PopupWindowBackgroundState { 0x7f0300cf }
+int styleable PopupWindowBackgroundState_state_above_anchor 0
+int[] styleable RecycleListView { 0x7f0300ac, 0x7f0300af }
+int styleable RecycleListView_paddingBottomNoButtons 0
+int styleable RecycleListView_paddingTopNoTitle 1
+int[] styleable SearchView { 0x010100da, 0x0101011f, 0x01010220, 0x01010264, 0x7f030046, 0x7f030055, 0x7f030060, 0x7f03007f, 0x7f030087, 0x7f03008f, 0x7f0300b9, 0x7f0300ba, 0x7f0300bf, 0x7f0300c0, 0x7f0300d2, 0x7f0300d7, 0x7f030105 }
+int styleable SearchView_android_focusable 0
+int styleable SearchView_android_maxWidth 1
+int styleable SearchView_android_inputType 2
+int styleable SearchView_android_imeOptions 3
+int styleable SearchView_closeIcon 4
+int styleable SearchView_commitIcon 5
+int styleable SearchView_defaultQueryHint 6
+int styleable SearchView_goIcon 7
+int styleable SearchView_iconifiedByDefault 8
+int styleable SearchView_layout 9
+int styleable SearchView_queryBackground 10
+int styleable SearchView_queryHint 11
+int styleable SearchView_searchHintIcon 12
+int styleable SearchView_searchIcon 13
+int styleable SearchView_submitBackground 14
+int styleable SearchView_suggestionRowLayout 15
+int styleable SearchView_voiceIcon 16
+int[] styleable Spinner { 0x010100b2, 0x01010176, 0x0101017b, 0x01010262, 0x7f0300b4 }
+int styleable Spinner_android_entries 0
+int styleable Spinner_android_popupBackground 1
+int styleable Spinner_android_prompt 2
+int styleable Spinner_android_dropDownWidth 3
+int styleable Spinner_popupTheme 4
+int[] styleable SwitchCompat { 0x01010124, 0x01010125, 0x01010142, 0x7f0300c7, 0x7f0300cd, 0x7f0300d8, 0x7f0300d9, 0x7f0300db, 0x7f0300e9, 0x7f0300ea, 0x7f0300eb, 0x7f030100, 0x7f030101, 0x7f030102 }
+int styleable SwitchCompat_android_textOn 0
+int styleable SwitchCompat_android_textOff 1
+int styleable SwitchCompat_android_thumb 2
+int styleable SwitchCompat_showText 3
+int styleable SwitchCompat_splitTrack 4
+int styleable SwitchCompat_switchMinWidth 5
+int styleable SwitchCompat_switchPadding 6
+int styleable SwitchCompat_switchTextAppearance 7
+int styleable SwitchCompat_thumbTextPadding 8
+int styleable SwitchCompat_thumbTint 9
+int styleable SwitchCompat_thumbTintMode 10
+int styleable SwitchCompat_track 11
+int styleable SwitchCompat_trackTint 12
+int styleable SwitchCompat_trackTintMode 13
+int[] styleable TextAppearance { 0x01010095, 0x01010096, 0x01010097, 0x01010098, 0x0101009a, 0x0101009b, 0x01010161, 0x01010162, 0x01010163, 0x01010164, 0x010103ac, 0x7f030074, 0x7f0300dc }
+int styleable TextAppearance_android_textSize 0
+int styleable TextAppearance_android_typeface 1
+int styleable TextAppearance_android_textStyle 2
+int styleable TextAppearance_android_textColor 3
+int styleable TextAppearance_android_textColorHint 4
+int styleable TextAppearance_android_textColorLink 5
+int styleable TextAppearance_android_shadowColor 6
+int styleable TextAppearance_android_shadowDx 7
+int styleable TextAppearance_android_shadowDy 8
+int styleable TextAppearance_android_shadowRadius 9
+int styleable TextAppearance_android_fontFamily 10
+int styleable TextAppearance_fontFamily 11
+int styleable TextAppearance_textAllCaps 12
+int[] styleable Toolbar { 0x010100af, 0x01010140, 0x7f03003d, 0x7f030048, 0x7f030049, 0x7f030057, 0x7f030058, 0x7f030059, 0x7f03005a, 0x7f03005b, 0x7f03005c, 0x7f0300a2, 0x7f0300a3, 0x7f0300a4, 0x7f0300a7, 0x7f0300a8, 0x7f0300b4, 0x7f0300d3, 0x7f0300d4, 0x7f0300d5, 0x7f0300f1, 0x7f0300f2, 0x7f0300f3, 0x7f0300f4, 0x7f0300f5, 0x7f0300f6, 0x7f0300f7, 0x7f0300f8, 0x7f0300f9 }
+int styleable Toolbar_android_gravity 0
+int styleable Toolbar_android_minHeight 1
+int styleable Toolbar_buttonGravity 2
+int styleable Toolbar_collapseContentDescription 3
+int styleable Toolbar_collapseIcon 4
+int styleable Toolbar_contentInsetEnd 5
+int styleable Toolbar_contentInsetEndWithActions 6
+int styleable Toolbar_contentInsetLeft 7
+int styleable Toolbar_contentInsetRight 8
+int styleable Toolbar_contentInsetStart 9
+int styleable Toolbar_contentInsetStartWithNavigation 10
+int styleable Toolbar_logo 11
+int styleable Toolbar_logoDescription 12
+int styleable Toolbar_maxButtonHeight 13
+int styleable Toolbar_navigationContentDescription 14
+int styleable Toolbar_navigationIcon 15
+int styleable Toolbar_popupTheme 16
+int styleable Toolbar_subtitle 17
+int styleable Toolbar_subtitleTextAppearance 18
+int styleable Toolbar_subtitleTextColor 19
+int styleable Toolbar_title 20
+int styleable Toolbar_titleMargin 21
+int styleable Toolbar_titleMarginBottom 22
+int styleable Toolbar_titleMarginEnd 23
+int styleable Toolbar_titleMarginStart 24
+int styleable Toolbar_titleMarginTop 25
+int styleable Toolbar_titleMargins 26
+int styleable Toolbar_titleTextAppearance 27
+int styleable Toolbar_titleTextColor 28
+int[] styleable View { 0x01010000, 0x010100da, 0x7f0300ad, 0x7f0300ae, 0x7f0300e7 }
+int styleable View_android_theme 0
+int styleable View_android_focusable 1
+int styleable View_paddingEnd 2
+int styleable View_paddingStart 3
+int styleable View_theme 4
+int[] styleable ViewBackgroundHelper { 0x010100d4, 0x7f030034, 0x7f030035 }
+int styleable ViewBackgroundHelper_android_background 0
+int styleable ViewBackgroundHelper_backgroundTint 1
+int styleable ViewBackgroundHelper_backgroundTintMode 2
+int[] styleable ViewStubCompat { 0x010100d0, 0x010100f2, 0x010100f3 }
+int styleable ViewStubCompat_android_id 0
+int styleable ViewStubCompat_android_layout 1
+int styleable ViewStubCompat_android_inflatedId 2
+int xml preferences 0x7f110000
+int xml searchable 0x7f110001
+int xml widget_2x_info 0x7f110002
+int xml widget_4x_info 0x7f110003
diff --git a/src/src/app/build/intermediates/runtime_symbol_list/debugAndroidTest/R.txt b/src/src/app/build/intermediates/runtime_symbol_list/debugAndroidTest/R.txt
new file mode 100644
index 0000000..e69de29
diff --git a/src/src/app/build/intermediates/symbol_list_with_package_name/debug/package-aware-r.txt b/src/src/app/build/intermediates/symbol_list_with_package_name/debug/package-aware-r.txt
new file mode 100644
index 0000000..781641e
--- /dev/null
+++ b/src/src/app/build/intermediates/symbol_list_with_package_name/debug/package-aware-r.txt
@@ -0,0 +1,1534 @@
+net.micode.notes
+anim abc_fade_in
+anim abc_fade_out
+anim abc_grow_fade_in_from_bottom
+anim abc_popup_enter
+anim abc_popup_exit
+anim abc_shrink_fade_out_from_bottom
+anim abc_slide_in_bottom
+anim abc_slide_in_top
+anim abc_slide_out_bottom
+anim abc_slide_out_top
+anim abc_tooltip_enter
+anim abc_tooltip_exit
+array format_for_exported_note
+array menu_share_ways
+attr actionBarDivider
+attr actionBarItemBackground
+attr actionBarPopupTheme
+attr actionBarSize
+attr actionBarSplitStyle
+attr actionBarStyle
+attr actionBarTabBarStyle
+attr actionBarTabStyle
+attr actionBarTabTextStyle
+attr actionBarTheme
+attr actionBarWidgetTheme
+attr actionButtonStyle
+attr actionDropDownStyle
+attr actionLayout
+attr actionMenuTextAppearance
+attr actionMenuTextColor
+attr actionModeBackground
+attr actionModeCloseButtonStyle
+attr actionModeCloseDrawable
+attr actionModeCopyDrawable
+attr actionModeCutDrawable
+attr actionModeFindDrawable
+attr actionModePasteDrawable
+attr actionModePopupWindowStyle
+attr actionModeSelectAllDrawable
+attr actionModeShareDrawable
+attr actionModeSplitBackground
+attr actionModeStyle
+attr actionModeWebSearchDrawable
+attr actionOverflowButtonStyle
+attr actionOverflowMenuStyle
+attr actionProviderClass
+attr actionViewClass
+attr activityChooserViewStyle
+attr alertDialogButtonGroupStyle
+attr alertDialogCenterButtons
+attr alertDialogStyle
+attr alertDialogTheme
+attr allowStacking
+attr alpha
+attr alphabeticModifiers
+attr arrowHeadLength
+attr arrowShaftLength
+attr autoCompleteTextViewStyle
+attr autoSizeMaxTextSize
+attr autoSizeMinTextSize
+attr autoSizePresetSizes
+attr autoSizeStepGranularity
+attr autoSizeTextType
+attr background
+attr backgroundSplit
+attr backgroundStacked
+attr backgroundTint
+attr backgroundTintMode
+attr barLength
+attr borderlessButtonStyle
+attr buttonBarButtonStyle
+attr buttonBarNegativeButtonStyle
+attr buttonBarNeutralButtonStyle
+attr buttonBarPositiveButtonStyle
+attr buttonBarStyle
+attr buttonGravity
+attr buttonIconDimen
+attr buttonPanelSideLayout
+attr buttonStyle
+attr buttonStyleSmall
+attr buttonTint
+attr buttonTintMode
+attr checkboxStyle
+attr checkedTextViewStyle
+attr closeIcon
+attr closeItemLayout
+attr collapseContentDescription
+attr collapseIcon
+attr color
+attr colorAccent
+attr colorBackgroundFloating
+attr colorButtonNormal
+attr colorControlActivated
+attr colorControlHighlight
+attr colorControlNormal
+attr colorError
+attr colorPrimary
+attr colorPrimaryDark
+attr colorSwitchThumbNormal
+attr commitIcon
+attr contentDescription
+attr contentInsetEnd
+attr contentInsetEndWithActions
+attr contentInsetLeft
+attr contentInsetRight
+attr contentInsetStart
+attr contentInsetStartWithNavigation
+attr controlBackground
+attr coordinatorLayoutStyle
+attr customNavigationLayout
+attr defaultQueryHint
+attr dialogCornerRadius
+attr dialogPreferredPadding
+attr dialogTheme
+attr displayOptions
+attr divider
+attr dividerHorizontal
+attr dividerPadding
+attr dividerVertical
+attr drawableSize
+attr drawerArrowStyle
+attr dropDownListViewStyle
+attr dropdownListPreferredItemHeight
+attr editTextBackground
+attr editTextColor
+attr editTextStyle
+attr elevation
+attr expandActivityOverflowButtonDrawable
+attr firstBaselineToTopHeight
+attr font
+attr fontFamily
+attr fontProviderAuthority
+attr fontProviderCerts
+attr fontProviderFetchStrategy
+attr fontProviderFetchTimeout
+attr fontProviderPackage
+attr fontProviderQuery
+attr fontStyle
+attr fontVariationSettings
+attr fontWeight
+attr gapBetweenBars
+attr goIcon
+attr height
+attr hideOnContentScroll
+attr homeAsUpIndicator
+attr homeLayout
+attr icon
+attr iconTint
+attr iconTintMode
+attr iconifiedByDefault
+attr imageButtonStyle
+attr indeterminateProgressStyle
+attr initialActivityCount
+attr isLightTheme
+attr itemPadding
+attr keylines
+attr lastBaselineToBottomHeight
+attr layout
+attr layout_anchor
+attr layout_anchorGravity
+attr layout_behavior
+attr layout_dodgeInsetEdges
+attr layout_insetEdge
+attr layout_keyline
+attr lineHeight
+attr listChoiceBackgroundIndicator
+attr listDividerAlertDialog
+attr listItemLayout
+attr listLayout
+attr listMenuViewStyle
+attr listPopupWindowStyle
+attr listPreferredItemHeight
+attr listPreferredItemHeightLarge
+attr listPreferredItemHeightSmall
+attr listPreferredItemPaddingLeft
+attr listPreferredItemPaddingRight
+attr logo
+attr logoDescription
+attr maxButtonHeight
+attr measureWithLargestChild
+attr multiChoiceItemLayout
+attr navigationContentDescription
+attr navigationIcon
+attr navigationMode
+attr numericModifiers
+attr overlapAnchor
+attr paddingBottomNoButtons
+attr paddingEnd
+attr paddingStart
+attr paddingTopNoTitle
+attr panelBackground
+attr panelMenuListTheme
+attr panelMenuListWidth
+attr popupMenuStyle
+attr popupTheme
+attr popupWindowStyle
+attr preserveIconSpacing
+attr progressBarPadding
+attr progressBarStyle
+attr queryBackground
+attr queryHint
+attr radioButtonStyle
+attr ratingBarStyle
+attr ratingBarStyleIndicator
+attr ratingBarStyleSmall
+attr searchHintIcon
+attr searchIcon
+attr searchViewStyle
+attr seekBarStyle
+attr selectableItemBackground
+attr selectableItemBackgroundBorderless
+attr showAsAction
+attr showDividers
+attr showText
+attr showTitle
+attr singleChoiceItemLayout
+attr spinBars
+attr spinnerDropDownItemStyle
+attr spinnerStyle
+attr splitTrack
+attr srcCompat
+attr state_above_anchor
+attr statusBarBackground
+attr subMenuArrow
+attr submitBackground
+attr subtitle
+attr subtitleTextAppearance
+attr subtitleTextColor
+attr subtitleTextStyle
+attr suggestionRowLayout
+attr switchMinWidth
+attr switchPadding
+attr switchStyle
+attr switchTextAppearance
+attr textAllCaps
+attr textAppearanceLargePopupMenu
+attr textAppearanceListItem
+attr textAppearanceListItemSecondary
+attr textAppearanceListItemSmall
+attr textAppearancePopupMenuHeader
+attr textAppearanceSearchResultSubtitle
+attr textAppearanceSearchResultTitle
+attr textAppearanceSmallPopupMenu
+attr textColorAlertDialogListItem
+attr textColorSearchUrl
+attr theme
+attr thickness
+attr thumbTextPadding
+attr thumbTint
+attr thumbTintMode
+attr tickMark
+attr tickMarkTint
+attr tickMarkTintMode
+attr tint
+attr tintMode
+attr title
+attr titleMargin
+attr titleMarginBottom
+attr titleMarginEnd
+attr titleMarginStart
+attr titleMarginTop
+attr titleMargins
+attr titleTextAppearance
+attr titleTextColor
+attr titleTextStyle
+attr toolbarNavigationButtonStyle
+attr toolbarStyle
+attr tooltipForegroundColor
+attr tooltipFrameBackground
+attr tooltipText
+attr track
+attr trackTint
+attr trackTintMode
+attr ttcIndex
+attr viewInflaterClass
+attr voiceIcon
+attr windowActionBar
+attr windowActionBarOverlay
+attr windowActionModeOverlay
+attr windowFixedHeightMajor
+attr windowFixedHeightMinor
+attr windowFixedWidthMajor
+attr windowFixedWidthMinor
+attr windowMinWidthMajor
+attr windowMinWidthMinor
+attr windowNoTitle
+bool abc_action_bar_embed_tabs
+bool abc_allow_stacked_button_bar
+bool abc_config_actionMenuItemAllCaps
+color abc_background_cache_hint_selector_material_dark
+color abc_background_cache_hint_selector_material_light
+color abc_btn_colored_borderless_text_material
+color abc_btn_colored_text_material
+color abc_color_highlight_material
+color abc_hint_foreground_material_dark
+color abc_hint_foreground_material_light
+color abc_input_method_navigation_guard
+color abc_primary_text_disable_only_material_dark
+color abc_primary_text_disable_only_material_light
+color abc_primary_text_material_dark
+color abc_primary_text_material_light
+color abc_search_url_text
+color abc_search_url_text_normal
+color abc_search_url_text_pressed
+color abc_search_url_text_selected
+color abc_secondary_text_material_dark
+color abc_secondary_text_material_light
+color abc_tint_btn_checkable
+color abc_tint_default
+color abc_tint_edittext
+color abc_tint_seek_thumb
+color abc_tint_spinner
+color abc_tint_switch_track
+color accent_material_dark
+color accent_material_light
+color background_floating_material_dark
+color background_floating_material_light
+color background_material_dark
+color background_material_light
+color bright_foreground_disabled_material_dark
+color bright_foreground_disabled_material_light
+color bright_foreground_inverse_material_dark
+color bright_foreground_inverse_material_light
+color bright_foreground_material_dark
+color bright_foreground_material_light
+color button_material_dark
+color button_material_light
+color dim_foreground_disabled_material_dark
+color dim_foreground_disabled_material_light
+color dim_foreground_material_dark
+color dim_foreground_material_light
+color error_color_material_dark
+color error_color_material_light
+color foreground_material_dark
+color foreground_material_light
+color highlighted_text_material_dark
+color highlighted_text_material_light
+color material_blue_grey_800
+color material_blue_grey_900
+color material_blue_grey_950
+color material_deep_teal_200
+color material_deep_teal_500
+color material_grey_100
+color material_grey_300
+color material_grey_50
+color material_grey_600
+color material_grey_800
+color material_grey_850
+color material_grey_900
+color notification_action_color_filter
+color notification_icon_bg_color
+color notification_material_background_media_default_color
+color primary_dark_material_dark
+color primary_dark_material_light
+color primary_material_dark
+color primary_material_light
+color primary_text_dark
+color primary_text_default_material_dark
+color primary_text_default_material_light
+color primary_text_disabled_material_dark
+color primary_text_disabled_material_light
+color ripple_material_dark
+color ripple_material_light
+color secondary_text_dark
+color secondary_text_default_material_dark
+color secondary_text_default_material_light
+color secondary_text_disabled_material_dark
+color secondary_text_disabled_material_light
+color switch_thumb_disabled_material_dark
+color switch_thumb_disabled_material_light
+color switch_thumb_material_dark
+color switch_thumb_material_light
+color switch_thumb_normal_material_dark
+color switch_thumb_normal_material_light
+color tooltip_background_dark
+color tooltip_background_light
+color user_query_highlight
+dimen abc_action_bar_content_inset_material
+dimen abc_action_bar_content_inset_with_nav
+dimen abc_action_bar_default_height_material
+dimen abc_action_bar_default_padding_end_material
+dimen abc_action_bar_default_padding_start_material
+dimen abc_action_bar_elevation_material
+dimen abc_action_bar_icon_vertical_padding_material
+dimen abc_action_bar_overflow_padding_end_material
+dimen abc_action_bar_overflow_padding_start_material
+dimen abc_action_bar_stacked_max_height
+dimen abc_action_bar_stacked_tab_max_width
+dimen abc_action_bar_subtitle_bottom_margin_material
+dimen abc_action_bar_subtitle_top_margin_material
+dimen abc_action_button_min_height_material
+dimen abc_action_button_min_width_material
+dimen abc_action_button_min_width_overflow_material
+dimen abc_alert_dialog_button_bar_height
+dimen abc_alert_dialog_button_dimen
+dimen abc_button_inset_horizontal_material
+dimen abc_button_inset_vertical_material
+dimen abc_button_padding_horizontal_material
+dimen abc_button_padding_vertical_material
+dimen abc_cascading_menus_min_smallest_width
+dimen abc_config_prefDialogWidth
+dimen abc_control_corner_material
+dimen abc_control_inset_material
+dimen abc_control_padding_material
+dimen abc_dialog_corner_radius_material
+dimen abc_dialog_fixed_height_major
+dimen abc_dialog_fixed_height_minor
+dimen abc_dialog_fixed_width_major
+dimen abc_dialog_fixed_width_minor
+dimen abc_dialog_list_padding_bottom_no_buttons
+dimen abc_dialog_list_padding_top_no_title
+dimen abc_dialog_min_width_major
+dimen abc_dialog_min_width_minor
+dimen abc_dialog_padding_material
+dimen abc_dialog_padding_top_material
+dimen abc_dialog_title_divider_material
+dimen abc_disabled_alpha_material_dark
+dimen abc_disabled_alpha_material_light
+dimen abc_dropdownitem_icon_width
+dimen abc_dropdownitem_text_padding_left
+dimen abc_dropdownitem_text_padding_right
+dimen abc_edit_text_inset_bottom_material
+dimen abc_edit_text_inset_horizontal_material
+dimen abc_edit_text_inset_top_material
+dimen abc_floating_window_z
+dimen abc_list_item_padding_horizontal_material
+dimen abc_panel_menu_list_width
+dimen abc_progress_bar_height_material
+dimen abc_search_view_preferred_height
+dimen abc_search_view_preferred_width
+dimen abc_seekbar_track_background_height_material
+dimen abc_seekbar_track_progress_height_material
+dimen abc_select_dialog_padding_start_material
+dimen abc_switch_padding
+dimen abc_text_size_body_1_material
+dimen abc_text_size_body_2_material
+dimen abc_text_size_button_material
+dimen abc_text_size_caption_material
+dimen abc_text_size_display_1_material
+dimen abc_text_size_display_2_material
+dimen abc_text_size_display_3_material
+dimen abc_text_size_display_4_material
+dimen abc_text_size_headline_material
+dimen abc_text_size_large_material
+dimen abc_text_size_medium_material
+dimen abc_text_size_menu_header_material
+dimen abc_text_size_menu_material
+dimen abc_text_size_small_material
+dimen abc_text_size_subhead_material
+dimen abc_text_size_subtitle_material_toolbar
+dimen abc_text_size_title_material
+dimen abc_text_size_title_material_toolbar
+dimen compat_button_inset_horizontal_material
+dimen compat_button_inset_vertical_material
+dimen compat_button_padding_horizontal_material
+dimen compat_button_padding_vertical_material
+dimen compat_control_corner_material
+dimen compat_notification_large_icon_max_height
+dimen compat_notification_large_icon_max_width
+dimen disabled_alpha_material_dark
+dimen disabled_alpha_material_light
+dimen highlight_alpha_material_colored
+dimen highlight_alpha_material_dark
+dimen highlight_alpha_material_light
+dimen hint_alpha_material_dark
+dimen hint_alpha_material_light
+dimen hint_pressed_alpha_material_dark
+dimen hint_pressed_alpha_material_light
+dimen notification_action_icon_size
+dimen notification_action_text_size
+dimen notification_big_circle_margin
+dimen notification_content_margin_start
+dimen notification_large_icon_height
+dimen notification_large_icon_width
+dimen notification_main_column_padding_top
+dimen notification_media_narrow_margin
+dimen notification_right_icon_size
+dimen notification_right_side_padding_top
+dimen notification_small_icon_background_padding
+dimen notification_small_icon_size_as_large
+dimen notification_subtext_size
+dimen notification_top_pad
+dimen notification_top_pad_large_text
+dimen subtitle_corner_radius
+dimen subtitle_outline_width
+dimen subtitle_shadow_offset
+dimen subtitle_shadow_radius
+dimen text_font_size_large
+dimen text_font_size_medium
+dimen text_font_size_normal
+dimen text_font_size_small
+dimen text_font_size_super
+dimen tooltip_corner_radius
+dimen tooltip_horizontal_padding
+dimen tooltip_margin
+dimen tooltip_precise_anchor_extra_offset
+dimen tooltip_precise_anchor_threshold
+dimen tooltip_vertical_padding
+dimen tooltip_y_offset_non_touch
+dimen tooltip_y_offset_touch
+drawable abc_ab_share_pack_mtrl_alpha
+drawable abc_action_bar_item_background_material
+drawable abc_btn_borderless_material
+drawable abc_btn_check_material
+drawable abc_btn_check_to_on_mtrl_000
+drawable abc_btn_check_to_on_mtrl_015
+drawable abc_btn_colored_material
+drawable abc_btn_default_mtrl_shape
+drawable abc_btn_radio_material
+drawable abc_btn_radio_to_on_mtrl_000
+drawable abc_btn_radio_to_on_mtrl_015
+drawable abc_btn_switch_to_on_mtrl_00001
+drawable abc_btn_switch_to_on_mtrl_00012
+drawable abc_cab_background_internal_bg
+drawable abc_cab_background_top_material
+drawable abc_cab_background_top_mtrl_alpha
+drawable abc_control_background_material
+drawable abc_dialog_material_background
+drawable abc_edit_text_material
+drawable abc_ic_ab_back_material
+drawable abc_ic_arrow_drop_right_black_24dp
+drawable abc_ic_clear_material
+drawable abc_ic_commit_search_api_mtrl_alpha
+drawable abc_ic_go_search_api_material
+drawable abc_ic_menu_copy_mtrl_am_alpha
+drawable abc_ic_menu_cut_mtrl_alpha
+drawable abc_ic_menu_overflow_material
+drawable abc_ic_menu_paste_mtrl_am_alpha
+drawable abc_ic_menu_selectall_mtrl_alpha
+drawable abc_ic_menu_share_mtrl_alpha
+drawable abc_ic_search_api_material
+drawable abc_ic_star_black_16dp
+drawable abc_ic_star_black_36dp
+drawable abc_ic_star_black_48dp
+drawable abc_ic_star_half_black_16dp
+drawable abc_ic_star_half_black_36dp
+drawable abc_ic_star_half_black_48dp
+drawable abc_ic_voice_search_api_material
+drawable abc_item_background_holo_dark
+drawable abc_item_background_holo_light
+drawable abc_list_divider_material
+drawable abc_list_divider_mtrl_alpha
+drawable abc_list_focused_holo
+drawable abc_list_longpressed_holo
+drawable abc_list_pressed_holo_dark
+drawable abc_list_pressed_holo_light
+drawable abc_list_selector_background_transition_holo_dark
+drawable abc_list_selector_background_transition_holo_light
+drawable abc_list_selector_disabled_holo_dark
+drawable abc_list_selector_disabled_holo_light
+drawable abc_list_selector_holo_dark
+drawable abc_list_selector_holo_light
+drawable abc_menu_hardkey_panel_mtrl_mult
+drawable abc_popup_background_mtrl_mult
+drawable abc_ratingbar_indicator_material
+drawable abc_ratingbar_material
+drawable abc_ratingbar_small_material
+drawable abc_scrubber_control_off_mtrl_alpha
+drawable abc_scrubber_control_to_pressed_mtrl_000
+drawable abc_scrubber_control_to_pressed_mtrl_005
+drawable abc_scrubber_primary_mtrl_alpha
+drawable abc_scrubber_track_mtrl_alpha
+drawable abc_seekbar_thumb_material
+drawable abc_seekbar_tick_mark_material
+drawable abc_seekbar_track_material
+drawable abc_spinner_mtrl_am_alpha
+drawable abc_spinner_textfield_background_material
+drawable abc_switch_thumb_material
+drawable abc_switch_track_mtrl_alpha
+drawable abc_tab_indicator_material
+drawable abc_tab_indicator_mtrl_alpha
+drawable abc_text_cursor_material
+drawable abc_text_select_handle_left_mtrl_dark
+drawable abc_text_select_handle_left_mtrl_light
+drawable abc_text_select_handle_middle_mtrl_dark
+drawable abc_text_select_handle_middle_mtrl_light
+drawable abc_text_select_handle_right_mtrl_dark
+drawable abc_text_select_handle_right_mtrl_light
+drawable abc_textfield_activated_mtrl_alpha
+drawable abc_textfield_default_mtrl_alpha
+drawable abc_textfield_search_activated_mtrl_alpha
+drawable abc_textfield_search_default_mtrl_alpha
+drawable abc_textfield_search_material
+drawable abc_vector_test
+drawable bg_btn_set_color
+drawable bg_color_btn_mask
+drawable call_record
+drawable clock
+drawable delete
+drawable dropdown_icon
+drawable edit_blue
+drawable edit_green
+drawable edit_red
+drawable edit_title_blue
+drawable edit_title_green
+drawable edit_title_red
+drawable edit_title_white
+drawable edit_title_yellow
+drawable edit_white
+drawable edit_yellow
+drawable font_large
+drawable font_normal
+drawable font_size_selector_bg
+drawable font_small
+drawable font_super
+drawable huaban
+drawable icon_app
+drawable key
+drawable list_background
+drawable list_blue_down
+drawable list_blue_middle
+drawable list_blue_single
+drawable list_blue_up
+drawable list_folder
+drawable list_footer_bg
+drawable list_green_down
+drawable list_green_middle
+drawable list_green_single
+drawable list_green_up
+drawable list_red_down
+drawable list_red_middle
+drawable list_red_single
+drawable list_red_up
+drawable list_white_down
+drawable list_white_middle
+drawable list_white_single
+drawable list_white_up
+drawable list_yellow_down
+drawable list_yellow_middle
+drawable list_yellow_single
+drawable list_yellow_up
+drawable menu_delete
+drawable menu_move
+drawable new_note
+drawable new_note_normal
+drawable new_note_pressed
+drawable note_edit_color_selector_panel
+drawable notification
+drawable notification_action_background
+drawable notification_bg
+drawable notification_bg_low
+drawable notification_bg_low_normal
+drawable notification_bg_low_pressed
+drawable notification_bg_normal
+drawable notification_bg_normal_pressed
+drawable notification_icon_background
+drawable notification_template_icon_bg
+drawable notification_template_icon_low_bg
+drawable notification_tile_bg
+drawable notify_panel_notification_icon_bg
+drawable search_result
+drawable selected
+drawable title_alert
+drawable title_bar_bg
+drawable tooltip_frame_dark
+drawable tooltip_frame_light
+drawable widget_2x_blue
+drawable widget_2x_green
+drawable widget_2x_red
+drawable widget_2x_white
+drawable widget_2x_yellow
+drawable widget_4x_blue
+drawable widget_4x_green
+drawable widget_4x_red
+drawable widget_4x_white
+drawable widget_4x_yellow
+id ALT
+id CTRL
+id CreateContactNote
+id CreateEventNote
+id CreateNewFolder
+id CreateNormalNote
+id CreatePasswdNote
+id FUNCTION
+id META
+id SHIFT
+id SYM
+id account_dialog_subtitle
+id account_dialog_title
+id action0
+id action_bar
+id action_bar_activity_content
+id action_bar_container
+id action_bar_root
+id action_bar_spinner
+id action_bar_subtitle
+id action_bar_title
+id action_container
+id action_context_bar
+id action_divider
+id action_image
+id action_menu_divider
+id action_menu_presenter
+id action_mode_bar
+id action_mode_bar_stub
+id action_mode_close_button
+id action_select_all
+id action_text
+id actions
+id activity_chooser_view_content
+id add
+id alertTitle
+id all
+id always
+id amPm
+id async
+id beginning
+id blocking
+id bottom
+id btn_new_note
+id btn_set_bg_color
+id buttonPanel
+id cancel_action
+id cb_edit_item
+id center
+id center_horizontal
+id center_vertical
+id checkbox
+id chronometer
+id clip_horizontal
+id clip_vertical
+id collapseActionView
+id content
+id contentPanel
+id custom
+id customPanel
+id date
+id decor_content_parent
+id default_activity_button
+id delete
+id disableHome
+id edit_query
+id end
+id end_padder
+id et_edit_text
+id et_foler_name
+id expand_activities_button
+id expanded_menu
+id fill
+id fill_horizontal
+id fill_vertical
+id font_size_selector
+id for_key
+id forever
+id gesture
+id gesture_view
+id gesture_view_name
+id group_divider
+id home
+id homeAsUp
+id hour
+id icon
+id icon_group
+id ifRoom
+id image
+id img_show
+id info
+id italic
+id iv_alert_icon
+id iv_bg_blue
+id iv_bg_blue_select
+id iv_bg_green
+id iv_bg_green_select
+id iv_bg_red
+id iv_bg_red_select
+id iv_bg_white
+id iv_bg_white_select
+id iv_bg_yellow
+id iv_bg_yellow_select
+id iv_image
+id iv_large_select
+id iv_medium_select
+id iv_small_select
+id iv_super_select
+id left
+id line1
+id line3
+id listMode
+id list_item
+id ll_font_large
+id ll_font_normal
+id ll_font_small
+id ll_font_super
+id media_actions
+id menu_alert
+id menu_camera
+id menu_delete
+id menu_delete_remind
+id menu_draw
+id menu_export_text
+id menu_font_size
+id menu_list_mode
+id menu_new_folder
+id menu_new_note
+id menu_search
+id menu_send_to_desktop
+id menu_setting
+id menu_share
+id menu_sync
+id message
+id middle
+id minute
+id move
+id multiply
+id myboard
+id navigation_bar
+id never
+id none
+id normal
+id note_bg_color_selector
+id note_edit_list
+id note_edit_view
+id note_item
+id note_title
+id notes_list
+id notification_background
+id notification_main_column
+id notification_main_column_container
+id parentPanel
+id password_hint
+id prefenerece_sync_status_textview
+id preference_sync_button
+id progress_circular
+id progress_horizontal
+id radio
+id radioGroup
+id right
+id right_icon
+id right_side
+id screen
+id scrollIndicatorDown
+id scrollIndicatorUp
+id scrollView
+id search_badge
+id search_bar
+id search_button
+id search_close_btn
+id search_edit_frame
+id search_go_btn
+id search_mag_icon
+id search_plate
+id search_src_text
+id search_voice_btn
+id select_dialog_listview
+id selection_menu
+id set_private_pwd
+id set_private_pwd_confirm
+id shortcut
+id showCustom
+id showHome
+id showTitle
+id spacer
+id split_action_bar
+id src_atop
+id src_in
+id src_over
+id start
+id status_bar_latest_event_content
+id submenuarrow
+id submit_area
+id sv_note_edit
+id tabMode
+id tag_transition_group
+id tag_unhandled_key_event_manager
+id tag_unhandled_key_listeners
+id text
+id text2
+id textSpacerNoButtons
+id textSpacerNoTitle
+id textView1
+id textView2
+id text_num
+id time
+id title
+id titleDividerNoCustom
+id title_template
+id top
+id topPanel
+id tv_alert_date
+id tv_folder_name
+id tv_modified_date
+id tv_name
+id tv_time
+id tv_title
+id tv_title_bar
+id uniform
+id up
+id useLogo
+id widget_bg_image
+id widget_text
+id withText
+id wrap_content
+integer abc_config_activityDefaultDur
+integer abc_config_activityShortDur
+integer cancel_button_image_alpha
+integer config_tooltipAnimTime
+integer status_bar_notification_info_maxnum
+layout abc_action_bar_title_item
+layout abc_action_bar_up_container
+layout abc_action_menu_item_layout
+layout abc_action_menu_layout
+layout abc_action_mode_bar
+layout abc_action_mode_close_item_material
+layout abc_activity_chooser_view
+layout abc_activity_chooser_view_list_item
+layout abc_alert_dialog_button_bar_material
+layout abc_alert_dialog_material
+layout abc_alert_dialog_title_material
+layout abc_cascading_menu_item_layout
+layout abc_dialog_title_material
+layout abc_expanded_menu_layout
+layout abc_list_menu_item_checkbox
+layout abc_list_menu_item_icon
+layout abc_list_menu_item_layout
+layout abc_list_menu_item_radio
+layout abc_popup_menu_header_item_layout
+layout abc_popup_menu_item_layout
+layout abc_screen_content_include
+layout abc_screen_simple
+layout abc_screen_simple_overlay_action_mode
+layout abc_screen_toolbar
+layout abc_search_dropdown_item_icons_2line
+layout abc_search_view
+layout abc_select_dialog_material
+layout abc_tooltip
+layout account_dialog_title
+layout add_account_text
+layout datetime_picker
+layout dialog_edit_text
+layout dialog_pwd
+layout dialog_pwd_confirm
+layout dialog_save
+layout folder_list_item
+layout gesture_setting
+layout myboard
+layout note_edit
+layout note_edit_list_item
+layout note_item
+layout note_list
+layout note_list_dropdown_menu
+layout note_list_footer
+layout notification_action
+layout notification_action_tombstone
+layout notification_media_action
+layout notification_media_cancel_action
+layout notification_template_big_media
+layout notification_template_big_media_custom
+layout notification_template_big_media_narrow
+layout notification_template_big_media_narrow_custom
+layout notification_template_custom_big
+layout notification_template_icon_group
+layout notification_template_lines_media
+layout notification_template_media
+layout notification_template_media_custom
+layout notification_template_part_chronometer
+layout notification_template_part_time
+layout select_dialog_item_material
+layout select_dialog_multichoice_material
+layout select_dialog_singlechoice_material
+layout settings_header
+layout support_simple_spinner_dropdown_item
+layout widget_2x
+layout widget_4x
+menu call_note_edit
+menu call_record_folder
+menu note_edit
+menu note_list
+menu note_list_dropdown
+menu note_list_options
+menu sub_folder
+plurals search_results_title
+raw contact
+raw event
+raw gestures
+raw introduction
+raw passwd
+string abc_action_bar_home_description
+string abc_action_bar_up_description
+string abc_action_menu_overflow_description
+string abc_action_mode_done
+string abc_activity_chooser_view_see_all
+string abc_activitychooserview_choose_application
+string abc_capital_off
+string abc_capital_on
+string abc_font_family_body_1_material
+string abc_font_family_body_2_material
+string abc_font_family_button_material
+string abc_font_family_caption_material
+string abc_font_family_display_1_material
+string abc_font_family_display_2_material
+string abc_font_family_display_3_material
+string abc_font_family_display_4_material
+string abc_font_family_headline_material
+string abc_font_family_menu_material
+string abc_font_family_subhead_material
+string abc_font_family_title_material
+string abc_menu_alt_shortcut_label
+string abc_menu_ctrl_shortcut_label
+string abc_menu_delete_shortcut_label
+string abc_menu_enter_shortcut_label
+string abc_menu_function_shortcut_label
+string abc_menu_meta_shortcut_label
+string abc_menu_shift_shortcut_label
+string abc_menu_space_shortcut_label
+string abc_menu_sym_shortcut_label
+string abc_prepend_shortcut_label
+string abc_search_hint
+string abc_searchview_description_clear
+string abc_searchview_description_query
+string abc_searchview_description_search
+string abc_searchview_description_submit
+string abc_searchview_description_voice
+string abc_shareactionprovider_share_with
+string abc_shareactionprovider_share_with_application
+string abc_toolbar_collapse_description
+string alert_message_delete_folder
+string alert_message_delete_note
+string alert_message_delete_notes
+string alert_title_delete
+string app_name
+string app_widget2x2
+string app_widget4x4
+string button_delete
+string call_record_folder_name
+string camera
+string datetime_dialog_cancel
+string datetime_dialog_ok
+string default_gesture
+string delete_remind_time_message
+string dialog_inputPwd
+string draw
+string error_note_empty_for_clock
+string error_note_empty_for_send_to_desktop
+string error_note_not_exist
+string error_sdcard_export
+string error_sdcard_unmounted
+string error_sync_cancelled
+string error_sync_internal
+string error_sync_network
+string failed_sdcard_export
+string file_name_txt_format
+string file_path
+string folder_exist
+string format_date_ymd
+string format_datetime_mdhm
+string format_exported_file_location
+string format_folder_files_count
+string format_move_notes_to_folder
+string hint_foler_name
+string info_note_enter_desktop
+string menu_LeavePrivate
+string menu_SetPrivate
+string menu_alert
+string menu_countAllNotes
+string menu_create_folder
+string menu_delete
+string menu_deselect_all
+string menu_export_text
+string menu_folder_change_name
+string menu_folder_delete
+string menu_folder_view
+string menu_font_large
+string menu_font_normal
+string menu_font_size
+string menu_font_small
+string menu_font_super
+string menu_list_mode
+string menu_move
+string menu_move_parent_folder
+string menu_normal_mode
+string menu_remove_remind
+string menu_search
+string menu_select_all
+string menu_select_none
+string menu_select_title
+string menu_send_to_desktop
+string menu_setting
+string menu_share
+string menu_sync
+string menu_sync_cancel
+string menu_title_select_folder
+string note_alert_expired
+string note_link_email
+string note_link_other
+string note_link_tel
+string note_link_web
+string notealert_enter
+string notealert_ok
+string notelist_menu_new
+string notelist_string_info
+string preferences_account_summary
+string preferences_account_title
+string preferences_add_account
+string preferences_bg_random_appear_title
+string preferences_button_sync_cancel
+string preferences_button_sync_immediately
+string preferences_dialog_change_account_title
+string preferences_dialog_change_account_warn_msg
+string preferences_dialog_select_account_tips
+string preferences_dialog_select_account_title
+string preferences_last_sync_time
+string preferences_last_sync_time_format
+string preferences_menu_cancel
+string preferences_menu_change_account
+string preferences_menu_remove_account
+string preferences_title
+string preferences_toast_cannot_change_account
+string preferences_toast_success_set_accout
+string search
+string search_hint
+string search_label
+string search_menu_title
+string search_setting_description
+string set_gesture
+string set_remind_time_message
+string status_bar_notification_info_overflow
+string success_sdcard_export
+string success_sync_account
+string sync_progress_init_list
+string sync_progress_login
+string sync_progress_syncing
+string take_photo
+string ticker_cancel
+string ticker_fail
+string ticker_success
+string ticker_syncing
+string widget_havenot_content
+string widget_under_visit_mode
+style AlertDialog_AppCompat
+style AlertDialog_AppCompat_Light
+style Animation_AppCompat_Dialog
+style Animation_AppCompat_DropDownUp
+style Animation_AppCompat_Tooltip
+style Base_AlertDialog_AppCompat
+style Base_AlertDialog_AppCompat_Light
+style Base_Animation_AppCompat_Dialog
+style Base_Animation_AppCompat_DropDownUp
+style Base_Animation_AppCompat_Tooltip
+style Base_DialogWindowTitle_AppCompat
+style Base_DialogWindowTitleBackground_AppCompat
+style Base_TextAppearance_AppCompat
+style Base_TextAppearance_AppCompat_Body1
+style Base_TextAppearance_AppCompat_Body2
+style Base_TextAppearance_AppCompat_Button
+style Base_TextAppearance_AppCompat_Caption
+style Base_TextAppearance_AppCompat_Display1
+style Base_TextAppearance_AppCompat_Display2
+style Base_TextAppearance_AppCompat_Display3
+style Base_TextAppearance_AppCompat_Display4
+style Base_TextAppearance_AppCompat_Headline
+style Base_TextAppearance_AppCompat_Inverse
+style Base_TextAppearance_AppCompat_Large
+style Base_TextAppearance_AppCompat_Large_Inverse
+style Base_TextAppearance_AppCompat_Light_Widget_PopupMenu_Large
+style Base_TextAppearance_AppCompat_Light_Widget_PopupMenu_Small
+style Base_TextAppearance_AppCompat_Medium
+style Base_TextAppearance_AppCompat_Medium_Inverse
+style Base_TextAppearance_AppCompat_Menu
+style Base_TextAppearance_AppCompat_SearchResult
+style Base_TextAppearance_AppCompat_SearchResult_Subtitle
+style Base_TextAppearance_AppCompat_SearchResult_Title
+style Base_TextAppearance_AppCompat_Small
+style Base_TextAppearance_AppCompat_Small_Inverse
+style Base_TextAppearance_AppCompat_Subhead
+style Base_TextAppearance_AppCompat_Subhead_Inverse
+style Base_TextAppearance_AppCompat_Title
+style Base_TextAppearance_AppCompat_Title_Inverse
+style Base_TextAppearance_AppCompat_Tooltip
+style Base_TextAppearance_AppCompat_Widget_ActionBar_Menu
+style Base_TextAppearance_AppCompat_Widget_ActionBar_Subtitle
+style Base_TextAppearance_AppCompat_Widget_ActionBar_Subtitle_Inverse
+style Base_TextAppearance_AppCompat_Widget_ActionBar_Title
+style Base_TextAppearance_AppCompat_Widget_ActionBar_Title_Inverse
+style Base_TextAppearance_AppCompat_Widget_ActionMode_Subtitle
+style Base_TextAppearance_AppCompat_Widget_ActionMode_Title
+style Base_TextAppearance_AppCompat_Widget_Button
+style Base_TextAppearance_AppCompat_Widget_Button_Borderless_Colored
+style Base_TextAppearance_AppCompat_Widget_Button_Colored
+style Base_TextAppearance_AppCompat_Widget_Button_Inverse
+style Base_TextAppearance_AppCompat_Widget_DropDownItem
+style Base_TextAppearance_AppCompat_Widget_PopupMenu_Header
+style Base_TextAppearance_AppCompat_Widget_PopupMenu_Large
+style Base_TextAppearance_AppCompat_Widget_PopupMenu_Small
+style Base_TextAppearance_AppCompat_Widget_Switch
+style Base_TextAppearance_AppCompat_Widget_TextView_SpinnerItem
+style Base_TextAppearance_Widget_AppCompat_ExpandedMenu_Item
+style Base_TextAppearance_Widget_AppCompat_Toolbar_Subtitle
+style Base_TextAppearance_Widget_AppCompat_Toolbar_Title
+style Base_Theme_AppCompat
+style Base_Theme_AppCompat_CompactMenu
+style Base_Theme_AppCompat_Dialog
+style Base_Theme_AppCompat_Dialog_Alert
+style Base_Theme_AppCompat_Dialog_FixedSize
+style Base_Theme_AppCompat_Dialog_MinWidth
+style Base_Theme_AppCompat_DialogWhenLarge
+style Base_Theme_AppCompat_Light
+style Base_Theme_AppCompat_Light_DarkActionBar
+style Base_Theme_AppCompat_Light_Dialog
+style Base_Theme_AppCompat_Light_Dialog_Alert
+style Base_Theme_AppCompat_Light_Dialog_FixedSize
+style Base_Theme_AppCompat_Light_Dialog_MinWidth
+style Base_Theme_AppCompat_Light_DialogWhenLarge
+style Base_ThemeOverlay_AppCompat
+style Base_ThemeOverlay_AppCompat_ActionBar
+style Base_ThemeOverlay_AppCompat_Dark
+style Base_ThemeOverlay_AppCompat_Dark_ActionBar
+style Base_ThemeOverlay_AppCompat_Dialog
+style Base_ThemeOverlay_AppCompat_Dialog_Alert
+style Base_ThemeOverlay_AppCompat_Light
+style Base_V21_Theme_AppCompat
+style Base_V21_Theme_AppCompat_Dialog
+style Base_V21_Theme_AppCompat_Light
+style Base_V21_Theme_AppCompat_Light_Dialog
+style Base_V21_ThemeOverlay_AppCompat_Dialog
+style Base_V22_Theme_AppCompat
+style Base_V22_Theme_AppCompat_Light
+style Base_V23_Theme_AppCompat
+style Base_V23_Theme_AppCompat_Light
+style Base_V26_Theme_AppCompat
+style Base_V26_Theme_AppCompat_Light
+style Base_V26_Widget_AppCompat_Toolbar
+style Base_V28_Theme_AppCompat
+style Base_V28_Theme_AppCompat_Light
+style Base_V7_Theme_AppCompat
+style Base_V7_Theme_AppCompat_Dialog
+style Base_V7_Theme_AppCompat_Light
+style Base_V7_Theme_AppCompat_Light_Dialog
+style Base_V7_ThemeOverlay_AppCompat_Dialog
+style Base_V7_Widget_AppCompat_AutoCompleteTextView
+style Base_V7_Widget_AppCompat_EditText
+style Base_V7_Widget_AppCompat_Toolbar
+style Base_Widget_AppCompat_ActionBar
+style Base_Widget_AppCompat_ActionBar_Solid
+style Base_Widget_AppCompat_ActionBar_TabBar
+style Base_Widget_AppCompat_ActionBar_TabText
+style Base_Widget_AppCompat_ActionBar_TabView
+style Base_Widget_AppCompat_ActionButton
+style Base_Widget_AppCompat_ActionButton_CloseMode
+style Base_Widget_AppCompat_ActionButton_Overflow
+style Base_Widget_AppCompat_ActionMode
+style Base_Widget_AppCompat_ActivityChooserView
+style Base_Widget_AppCompat_AutoCompleteTextView
+style Base_Widget_AppCompat_Button
+style Base_Widget_AppCompat_Button_Borderless
+style Base_Widget_AppCompat_Button_Borderless_Colored
+style Base_Widget_AppCompat_Button_ButtonBar_AlertDialog
+style Base_Widget_AppCompat_Button_Colored
+style Base_Widget_AppCompat_Button_Small
+style Base_Widget_AppCompat_ButtonBar
+style Base_Widget_AppCompat_ButtonBar_AlertDialog
+style Base_Widget_AppCompat_CompoundButton_CheckBox
+style Base_Widget_AppCompat_CompoundButton_RadioButton
+style Base_Widget_AppCompat_CompoundButton_Switch
+style Base_Widget_AppCompat_DrawerArrowToggle
+style Base_Widget_AppCompat_DrawerArrowToggle_Common
+style Base_Widget_AppCompat_DropDownItem_Spinner
+style Base_Widget_AppCompat_EditText
+style Base_Widget_AppCompat_ImageButton
+style Base_Widget_AppCompat_Light_ActionBar
+style Base_Widget_AppCompat_Light_ActionBar_Solid
+style Base_Widget_AppCompat_Light_ActionBar_TabBar
+style Base_Widget_AppCompat_Light_ActionBar_TabText
+style Base_Widget_AppCompat_Light_ActionBar_TabText_Inverse
+style Base_Widget_AppCompat_Light_ActionBar_TabView
+style Base_Widget_AppCompat_Light_PopupMenu
+style Base_Widget_AppCompat_Light_PopupMenu_Overflow
+style Base_Widget_AppCompat_ListMenuView
+style Base_Widget_AppCompat_ListPopupWindow
+style Base_Widget_AppCompat_ListView
+style Base_Widget_AppCompat_ListView_DropDown
+style Base_Widget_AppCompat_ListView_Menu
+style Base_Widget_AppCompat_PopupMenu
+style Base_Widget_AppCompat_PopupMenu_Overflow
+style Base_Widget_AppCompat_PopupWindow
+style Base_Widget_AppCompat_ProgressBar
+style Base_Widget_AppCompat_ProgressBar_Horizontal
+style Base_Widget_AppCompat_RatingBar
+style Base_Widget_AppCompat_RatingBar_Indicator
+style Base_Widget_AppCompat_RatingBar_Small
+style Base_Widget_AppCompat_SearchView
+style Base_Widget_AppCompat_SearchView_ActionBar
+style Base_Widget_AppCompat_SeekBar
+style Base_Widget_AppCompat_SeekBar_Discrete
+style Base_Widget_AppCompat_Spinner
+style Base_Widget_AppCompat_Spinner_Underlined
+style Base_Widget_AppCompat_TextView_SpinnerItem
+style Base_Widget_AppCompat_Toolbar
+style Base_Widget_AppCompat_Toolbar_Button_Navigation
+style HighlightTextAppearancePrimary
+style HighlightTextAppearanceSecondary
+style NoteActionBarStyle
+style NoteTheme
+style Platform_AppCompat
+style Platform_AppCompat_Light
+style Platform_ThemeOverlay_AppCompat
+style Platform_ThemeOverlay_AppCompat_Dark
+style Platform_ThemeOverlay_AppCompat_Light
+style Platform_V21_AppCompat
+style Platform_V21_AppCompat_Light
+style Platform_V25_AppCompat
+style Platform_V25_AppCompat_Light
+style Platform_Widget_AppCompat_Spinner
+style RtlOverlay_DialogWindowTitle_AppCompat
+style RtlOverlay_Widget_AppCompat_ActionBar_TitleItem
+style RtlOverlay_Widget_AppCompat_DialogTitle_Icon
+style RtlOverlay_Widget_AppCompat_PopupMenuItem
+style RtlOverlay_Widget_AppCompat_PopupMenuItem_InternalGroup
+style RtlOverlay_Widget_AppCompat_PopupMenuItem_Shortcut
+style RtlOverlay_Widget_AppCompat_PopupMenuItem_SubmenuArrow
+style RtlOverlay_Widget_AppCompat_PopupMenuItem_Text
+style RtlOverlay_Widget_AppCompat_PopupMenuItem_Title
+style RtlOverlay_Widget_AppCompat_Search_DropDown
+style RtlOverlay_Widget_AppCompat_Search_DropDown_Icon1
+style RtlOverlay_Widget_AppCompat_Search_DropDown_Icon2
+style RtlOverlay_Widget_AppCompat_Search_DropDown_Query
+style RtlOverlay_Widget_AppCompat_Search_DropDown_Text
+style RtlOverlay_Widget_AppCompat_SearchView_MagIcon
+style RtlUnderlay_Widget_AppCompat_ActionButton
+style RtlUnderlay_Widget_AppCompat_ActionButton_Overflow
+style TextAppearance_AppCompat
+style TextAppearance_AppCompat_Body1
+style TextAppearance_AppCompat_Body2
+style TextAppearance_AppCompat_Button
+style TextAppearance_AppCompat_Caption
+style TextAppearance_AppCompat_Display1
+style TextAppearance_AppCompat_Display2
+style TextAppearance_AppCompat_Display3
+style TextAppearance_AppCompat_Display4
+style TextAppearance_AppCompat_Headline
+style TextAppearance_AppCompat_Inverse
+style TextAppearance_AppCompat_Large
+style TextAppearance_AppCompat_Large_Inverse
+style TextAppearance_AppCompat_Light_SearchResult_Subtitle
+style TextAppearance_AppCompat_Light_SearchResult_Title
+style TextAppearance_AppCompat_Light_Widget_PopupMenu_Large
+style TextAppearance_AppCompat_Light_Widget_PopupMenu_Small
+style TextAppearance_AppCompat_Medium
+style TextAppearance_AppCompat_Medium_Inverse
+style TextAppearance_AppCompat_Menu
+style TextAppearance_AppCompat_SearchResult_Subtitle
+style TextAppearance_AppCompat_SearchResult_Title
+style TextAppearance_AppCompat_Small
+style TextAppearance_AppCompat_Small_Inverse
+style TextAppearance_AppCompat_Subhead
+style TextAppearance_AppCompat_Subhead_Inverse
+style TextAppearance_AppCompat_Title
+style TextAppearance_AppCompat_Title_Inverse
+style TextAppearance_AppCompat_Tooltip
+style TextAppearance_AppCompat_Widget_ActionBar_Menu
+style TextAppearance_AppCompat_Widget_ActionBar_Subtitle
+style TextAppearance_AppCompat_Widget_ActionBar_Subtitle_Inverse
+style TextAppearance_AppCompat_Widget_ActionBar_Title
+style TextAppearance_AppCompat_Widget_ActionBar_Title_Inverse
+style TextAppearance_AppCompat_Widget_ActionMode_Subtitle
+style TextAppearance_AppCompat_Widget_ActionMode_Subtitle_Inverse
+style TextAppearance_AppCompat_Widget_ActionMode_Title
+style TextAppearance_AppCompat_Widget_ActionMode_Title_Inverse
+style TextAppearance_AppCompat_Widget_Button
+style TextAppearance_AppCompat_Widget_Button_Borderless_Colored
+style TextAppearance_AppCompat_Widget_Button_Colored
+style TextAppearance_AppCompat_Widget_Button_Inverse
+style TextAppearance_AppCompat_Widget_DropDownItem
+style TextAppearance_AppCompat_Widget_PopupMenu_Header
+style TextAppearance_AppCompat_Widget_PopupMenu_Large
+style TextAppearance_AppCompat_Widget_PopupMenu_Small
+style TextAppearance_AppCompat_Widget_Switch
+style TextAppearance_AppCompat_Widget_TextView_SpinnerItem
+style TextAppearance_Compat_Notification
+style TextAppearance_Compat_Notification_Info
+style TextAppearance_Compat_Notification_Info_Media
+style TextAppearance_Compat_Notification_Line2
+style TextAppearance_Compat_Notification_Line2_Media
+style TextAppearance_Compat_Notification_Media
+style TextAppearance_Compat_Notification_Time
+style TextAppearance_Compat_Notification_Time_Media
+style TextAppearance_Compat_Notification_Title
+style TextAppearance_Compat_Notification_Title_Media
+style TextAppearance_Widget_AppCompat_ExpandedMenu_Item
+style TextAppearance_Widget_AppCompat_Toolbar_Subtitle
+style TextAppearance_Widget_AppCompat_Toolbar_Title
+style TextAppearanceLarge
+style TextAppearanceMedium
+style TextAppearanceNormal
+style TextAppearancePrimaryItem
+style TextAppearanceSecondaryItem
+style TextAppearanceSuper
+style TextAppearanceUnderMenuIcon
+style Theme_AppCompat
+style Theme_AppCompat_CompactMenu
+style Theme_AppCompat_DayNight
+style Theme_AppCompat_DayNight_DarkActionBar
+style Theme_AppCompat_DayNight_Dialog
+style Theme_AppCompat_DayNight_Dialog_Alert
+style Theme_AppCompat_DayNight_Dialog_MinWidth
+style Theme_AppCompat_DayNight_DialogWhenLarge
+style Theme_AppCompat_DayNight_NoActionBar
+style Theme_AppCompat_Dialog
+style Theme_AppCompat_Dialog_Alert
+style Theme_AppCompat_Dialog_MinWidth
+style Theme_AppCompat_DialogWhenLarge
+style Theme_AppCompat_Light
+style Theme_AppCompat_Light_DarkActionBar
+style Theme_AppCompat_Light_Dialog
+style Theme_AppCompat_Light_Dialog_Alert
+style Theme_AppCompat_Light_Dialog_MinWidth
+style Theme_AppCompat_Light_DialogWhenLarge
+style Theme_AppCompat_Light_NoActionBar
+style Theme_AppCompat_NoActionBar
+style ThemeOverlay_AppCompat
+style ThemeOverlay_AppCompat_ActionBar
+style ThemeOverlay_AppCompat_Dark
+style ThemeOverlay_AppCompat_Dark_ActionBar
+style ThemeOverlay_AppCompat_Dialog
+style ThemeOverlay_AppCompat_Dialog_Alert
+style ThemeOverlay_AppCompat_Light
+style Widget_AppCompat_ActionBar
+style Widget_AppCompat_ActionBar_Solid
+style Widget_AppCompat_ActionBar_TabBar
+style Widget_AppCompat_ActionBar_TabText
+style Widget_AppCompat_ActionBar_TabView
+style Widget_AppCompat_ActionButton
+style Widget_AppCompat_ActionButton_CloseMode
+style Widget_AppCompat_ActionButton_Overflow
+style Widget_AppCompat_ActionMode
+style Widget_AppCompat_ActivityChooserView
+style Widget_AppCompat_AutoCompleteTextView
+style Widget_AppCompat_Button
+style Widget_AppCompat_Button_Borderless
+style Widget_AppCompat_Button_Borderless_Colored
+style Widget_AppCompat_Button_ButtonBar_AlertDialog
+style Widget_AppCompat_Button_Colored
+style Widget_AppCompat_Button_Small
+style Widget_AppCompat_ButtonBar
+style Widget_AppCompat_ButtonBar_AlertDialog
+style Widget_AppCompat_CompoundButton_CheckBox
+style Widget_AppCompat_CompoundButton_RadioButton
+style Widget_AppCompat_CompoundButton_Switch
+style Widget_AppCompat_DrawerArrowToggle
+style Widget_AppCompat_DropDownItem_Spinner
+style Widget_AppCompat_EditText
+style Widget_AppCompat_ImageButton
+style Widget_AppCompat_Light_ActionBar
+style Widget_AppCompat_Light_ActionBar_Solid
+style Widget_AppCompat_Light_ActionBar_Solid_Inverse
+style Widget_AppCompat_Light_ActionBar_TabBar
+style Widget_AppCompat_Light_ActionBar_TabBar_Inverse
+style Widget_AppCompat_Light_ActionBar_TabText
+style Widget_AppCompat_Light_ActionBar_TabText_Inverse
+style Widget_AppCompat_Light_ActionBar_TabView
+style Widget_AppCompat_Light_ActionBar_TabView_Inverse
+style Widget_AppCompat_Light_ActionButton
+style Widget_AppCompat_Light_ActionButton_CloseMode
+style Widget_AppCompat_Light_ActionButton_Overflow
+style Widget_AppCompat_Light_ActionMode_Inverse
+style Widget_AppCompat_Light_ActivityChooserView
+style Widget_AppCompat_Light_AutoCompleteTextView
+style Widget_AppCompat_Light_DropDownItem_Spinner
+style Widget_AppCompat_Light_ListPopupWindow
+style Widget_AppCompat_Light_ListView_DropDown
+style Widget_AppCompat_Light_PopupMenu
+style Widget_AppCompat_Light_PopupMenu_Overflow
+style Widget_AppCompat_Light_SearchView
+style Widget_AppCompat_Light_Spinner_DropDown_ActionBar
+style Widget_AppCompat_ListMenuView
+style Widget_AppCompat_ListPopupWindow
+style Widget_AppCompat_ListView
+style Widget_AppCompat_ListView_DropDown
+style Widget_AppCompat_ListView_Menu
+style Widget_AppCompat_PopupMenu
+style Widget_AppCompat_PopupMenu_Overflow
+style Widget_AppCompat_PopupWindow
+style Widget_AppCompat_ProgressBar
+style Widget_AppCompat_ProgressBar_Horizontal
+style Widget_AppCompat_RatingBar
+style Widget_AppCompat_RatingBar_Indicator
+style Widget_AppCompat_RatingBar_Small
+style Widget_AppCompat_SearchView
+style Widget_AppCompat_SearchView_ActionBar
+style Widget_AppCompat_SeekBar
+style Widget_AppCompat_SeekBar_Discrete
+style Widget_AppCompat_Spinner
+style Widget_AppCompat_Spinner_DropDown
+style Widget_AppCompat_Spinner_DropDown_ActionBar
+style Widget_AppCompat_Spinner_Underlined
+style Widget_AppCompat_TextView_SpinnerItem
+style Widget_AppCompat_Toolbar
+style Widget_AppCompat_Toolbar_Button_Navigation
+style Widget_Compat_NotificationActionContainer
+style Widget_Compat_NotificationActionText
+style Widget_Support_CoordinatorLayout
+styleable ActionBar background backgroundSplit backgroundStacked contentInsetEnd contentInsetEndWithActions contentInsetLeft contentInsetRight contentInsetStart contentInsetStartWithNavigation customNavigationLayout displayOptions divider elevation height hideOnContentScroll homeAsUpIndicator homeLayout icon indeterminateProgressStyle itemPadding logo navigationMode popupTheme progressBarPadding progressBarStyle subtitle subtitleTextStyle title titleTextStyle
+styleable ActionBarLayout android_layout_gravity
+styleable ActionMenuItemView android_minWidth
+styleable ActionMenuView
+styleable ActionMode background backgroundSplit closeItemLayout height subtitleTextStyle titleTextStyle
+styleable ActivityChooserView expandActivityOverflowButtonDrawable initialActivityCount
+styleable AlertDialog android_layout buttonIconDimen buttonPanelSideLayout listItemLayout listLayout multiChoiceItemLayout showTitle singleChoiceItemLayout
+styleable AppCompatImageView android_src srcCompat tint tintMode
+styleable AppCompatSeekBar android_thumb tickMark tickMarkTint tickMarkTintMode
+styleable AppCompatTextHelper android_textAppearance android_drawableTop android_drawableBottom android_drawableLeft android_drawableRight android_drawableStart android_drawableEnd
+styleable AppCompatTextView android_textAppearance autoSizeMaxTextSize autoSizeMinTextSize autoSizePresetSizes autoSizeStepGranularity autoSizeTextType firstBaselineToTopHeight fontFamily lastBaselineToBottomHeight lineHeight textAllCaps
+styleable AppCompatTheme android_windowIsFloating android_windowAnimationStyle actionBarDivider actionBarItemBackground actionBarPopupTheme actionBarSize actionBarSplitStyle actionBarStyle actionBarTabBarStyle actionBarTabStyle actionBarTabTextStyle actionBarTheme actionBarWidgetTheme actionButtonStyle actionDropDownStyle actionMenuTextAppearance actionMenuTextColor actionModeBackground actionModeCloseButtonStyle actionModeCloseDrawable actionModeCopyDrawable actionModeCutDrawable actionModeFindDrawable actionModePasteDrawable actionModePopupWindowStyle actionModeSelectAllDrawable actionModeShareDrawable actionModeSplitBackground actionModeStyle actionModeWebSearchDrawable actionOverflowButtonStyle actionOverflowMenuStyle activityChooserViewStyle alertDialogButtonGroupStyle alertDialogCenterButtons alertDialogStyle alertDialogTheme autoCompleteTextViewStyle borderlessButtonStyle buttonBarButtonStyle buttonBarNegativeButtonStyle buttonBarNeutralButtonStyle buttonBarPositiveButtonStyle buttonBarStyle buttonStyle buttonStyleSmall checkboxStyle checkedTextViewStyle colorAccent colorBackgroundFloating colorButtonNormal colorControlActivated colorControlHighlight colorControlNormal colorError colorPrimary colorPrimaryDark colorSwitchThumbNormal controlBackground dialogCornerRadius dialogPreferredPadding dialogTheme dividerHorizontal dividerVertical dropDownListViewStyle dropdownListPreferredItemHeight editTextBackground editTextColor editTextStyle homeAsUpIndicator imageButtonStyle listChoiceBackgroundIndicator listDividerAlertDialog listMenuViewStyle listPopupWindowStyle listPreferredItemHeight listPreferredItemHeightLarge listPreferredItemHeightSmall listPreferredItemPaddingLeft listPreferredItemPaddingRight panelBackground panelMenuListTheme panelMenuListWidth popupMenuStyle popupWindowStyle radioButtonStyle ratingBarStyle ratingBarStyleIndicator ratingBarStyleSmall searchViewStyle seekBarStyle selectableItemBackground selectableItemBackgroundBorderless spinnerDropDownItemStyle spinnerStyle switchStyle textAppearanceLargePopupMenu textAppearanceListItem textAppearanceListItemSecondary textAppearanceListItemSmall textAppearancePopupMenuHeader textAppearanceSearchResultSubtitle textAppearanceSearchResultTitle textAppearanceSmallPopupMenu textColorAlertDialogListItem textColorSearchUrl toolbarNavigationButtonStyle toolbarStyle tooltipForegroundColor tooltipFrameBackground viewInflaterClass windowActionBar windowActionBarOverlay windowActionModeOverlay windowFixedHeightMajor windowFixedHeightMinor windowFixedWidthMajor windowFixedWidthMinor windowMinWidthMajor windowMinWidthMinor windowNoTitle
+styleable ButtonBarLayout allowStacking
+styleable ColorStateListItem android_color android_alpha alpha
+styleable CompoundButton android_button buttonTint buttonTintMode
+styleable CoordinatorLayout keylines statusBarBackground
+styleable CoordinatorLayout_Layout android_layout_gravity layout_anchor layout_anchorGravity layout_behavior layout_dodgeInsetEdges layout_insetEdge layout_keyline
+styleable DrawerArrowToggle arrowHeadLength arrowShaftLength barLength color drawableSize gapBetweenBars spinBars thickness
+styleable FontFamily fontProviderAuthority fontProviderCerts fontProviderFetchStrategy fontProviderFetchTimeout fontProviderPackage fontProviderQuery
+styleable FontFamilyFont android_font android_fontWeight android_fontStyle android_ttcIndex android_fontVariationSettings font fontStyle fontVariationSettings fontWeight ttcIndex
+styleable GradientColor android_startColor android_endColor android_type android_centerX android_centerY android_gradientRadius android_tileMode android_centerColor android_startX android_startY android_endX android_endY
+styleable GradientColorItem android_color android_offset
+styleable LinearLayoutCompat android_gravity android_orientation android_baselineAligned android_baselineAlignedChildIndex android_weightSum divider dividerPadding measureWithLargestChild showDividers
+styleable LinearLayoutCompat_Layout android_layout_gravity android_layout_width android_layout_height android_layout_weight
+styleable ListPopupWindow android_dropDownHorizontalOffset android_dropDownVerticalOffset
+styleable MenuGroup android_enabled android_id android_visible android_menuCategory android_orderInCategory android_checkableBehavior
+styleable MenuItem android_icon android_enabled android_id android_checked android_visible android_menuCategory android_orderInCategory android_title android_titleCondensed android_alphabeticShortcut android_numericShortcut android_checkable android_onClick actionLayout actionProviderClass actionViewClass alphabeticModifiers contentDescription iconTint iconTintMode numericModifiers showAsAction tooltipText
+styleable MenuView android_windowAnimationStyle android_itemTextAppearance android_horizontalDivider android_verticalDivider android_headerBackground android_itemBackground android_itemIconDisabledAlpha preserveIconSpacing subMenuArrow
+styleable PopupWindow android_popupBackground android_popupAnimationStyle overlapAnchor
+styleable PopupWindowBackgroundState state_above_anchor
+styleable RecycleListView paddingBottomNoButtons paddingTopNoTitle
+styleable SearchView android_focusable android_maxWidth android_inputType android_imeOptions closeIcon commitIcon defaultQueryHint goIcon iconifiedByDefault layout queryBackground queryHint searchHintIcon searchIcon submitBackground suggestionRowLayout voiceIcon
+styleable Spinner android_entries android_popupBackground android_prompt android_dropDownWidth popupTheme
+styleable SwitchCompat android_textOn android_textOff android_thumb showText splitTrack switchMinWidth switchPadding switchTextAppearance thumbTextPadding thumbTint thumbTintMode track trackTint trackTintMode
+styleable TextAppearance android_textSize android_typeface android_textStyle android_textColor android_textColorHint android_textColorLink android_shadowColor android_shadowDx android_shadowDy android_shadowRadius android_fontFamily fontFamily textAllCaps
+styleable Toolbar android_gravity android_minHeight buttonGravity collapseContentDescription collapseIcon contentInsetEnd contentInsetEndWithActions contentInsetLeft contentInsetRight contentInsetStart contentInsetStartWithNavigation logo logoDescription maxButtonHeight navigationContentDescription navigationIcon popupTheme subtitle subtitleTextAppearance subtitleTextColor title titleMargin titleMarginBottom titleMarginEnd titleMarginStart titleMarginTop titleMargins titleTextAppearance titleTextColor
+styleable View android_theme android_focusable paddingEnd paddingStart theme
+styleable ViewBackgroundHelper android_background backgroundTint backgroundTintMode
+styleable ViewStubCompat android_id android_layout android_inflatedId
+xml preferences
+xml searchable
+xml widget_2x_info
+xml widget_4x_info
diff --git a/src/src/app/build/outputs/apk/debug/app-debug.apk b/src/src/app/build/outputs/apk/debug/app-debug.apk
new file mode 100644
index 0000000..1bd2a42
Binary files /dev/null and b/src/src/app/build/outputs/apk/debug/app-debug.apk differ
diff --git a/src/src/app/build/outputs/apk/debug/output-metadata.json b/src/src/app/build/outputs/apk/debug/output-metadata.json
new file mode 100644
index 0000000..1d75db5
--- /dev/null
+++ b/src/src/app/build/outputs/apk/debug/output-metadata.json
@@ -0,0 +1,20 @@
+{
+ "version": 1,
+ "artifactType": {
+ "type": "APK",
+ "kind": "Directory"
+ },
+ "applicationId": "net.micode.notes",
+ "variantName": "debug",
+ "elements": [
+ {
+ "type": "SINGLE",
+ "filters": [],
+ "properties": [],
+ "versionCode": 1,
+ "versionName": "0.1",
+ "enabled": true,
+ "outputFile": "app-debug.apk"
+ }
+ ]
+}
\ No newline at end of file
diff --git a/src/src/app/build/outputs/logs/manifest-merger-debug-report.txt b/src/src/app/build/outputs/logs/manifest-merger-debug-report.txt
new file mode 100644
index 0000000..285b7fe
--- /dev/null
+++ b/src/src/app/build/outputs/logs/manifest-merger-debug-report.txt
@@ -0,0 +1,357 @@
+-- Merging decision tree log ---
+manifest
+ADDED from E:\Note\src\app\src\main\AndroidManifest.xml:18:1-166:12
+INJECTED from E:\Note\src\app\src\main\AndroidManifest.xml:18:1-166:12
+INJECTED from E:\Note\src\app\src\main\AndroidManifest.xml:18:1-166:12
+INJECTED from E:\Note\src\app\src\main\AndroidManifest.xml:18:1-166:12
+MERGED from [androidx.legacy:legacy-support-v4:1.0.0] C:\Users\\.gradle\caches\transforms-2\files-2.1\be0f08ddbc7b2ceb9beb29e6b731c207\legacy-support-v4-1.0.0\AndroidManifest.xml:17:1-22:12
+MERGED from [androidx.appcompat:appcompat:1.0.0-alpha1] C:\Users\\.gradle\caches\transforms-2\files-2.1\88c548461109b0c917067cfea58751b3\appcompat-1.0.0-alpha1\AndroidManifest.xml:17:1-22:12
+MERGED from [androidx.media:media:1.0.0] C:\Users\\.gradle\caches\transforms-2\files-2.1\702974eead929cb167f132efe0eabb04\media-1.0.0\AndroidManifest.xml:17:1-22:12
+MERGED from [androidx.fragment:fragment:1.0.0] C:\Users\\.gradle\caches\transforms-2\files-2.1\bbcbf6e10ae52a08d3f4cdfbe738c39d\fragment-1.0.0\AndroidManifest.xml:17:1-22:12
+MERGED from [androidx.vectordrawable:vectordrawable-animated:1.0.0-alpha1] C:\Users\\.gradle\caches\transforms-2\files-2.1\a7af7f043769db5be0b091cfc45cc012\vectordrawable-animated-1.0.0-alpha1\AndroidManifest.xml:17:1-22:12
+MERGED from [androidx.legacy:legacy-support-core-ui:1.0.0] C:\Users\\.gradle\caches\transforms-2\files-2.1\f5ec57ec49d0a3e9add695de66a9078c\legacy-support-core-ui-1.0.0\AndroidManifest.xml:17:1-22:12
+MERGED from [androidx.legacy:legacy-support-core-utils:1.0.0] C:\Users\\.gradle\caches\transforms-2\files-2.1\18f5c1f0dcc08504bb6a1709d838cf6b\legacy-support-core-utils-1.0.0\AndroidManifest.xml:17:1-22:12
+MERGED from [androidx.vectordrawable:vectordrawable:1.0.0-alpha1] C:\Users\\.gradle\caches\transforms-2\files-2.1\3c5008756363749b06d8984591aefc49\vectordrawable-1.0.0-alpha1\AndroidManifest.xml:17:1-22:12
+MERGED from [androidx.loader:loader:1.0.0] C:\Users\\.gradle\caches\transforms-2\files-2.1\2118a7099009bdd29f0289728ee82c0d\loader-1.0.0\AndroidManifest.xml:17:1-22:12
+MERGED from [androidx.viewpager:viewpager:1.0.0] C:\Users\\.gradle\caches\transforms-2\files-2.1\ebc8011c39d26c440b76466a9b971345\viewpager-1.0.0\AndroidManifest.xml:17:1-22:12
+MERGED from [androidx.coordinatorlayout:coordinatorlayout:1.0.0] C:\Users\\.gradle\caches\transforms-2\files-2.1\df8a19ef163eaa8f3d3c8f24458897fd\coordinatorlayout-1.0.0\AndroidManifest.xml:17:1-22:12
+MERGED from [androidx.drawerlayout:drawerlayout:1.0.0] C:\Users\\.gradle\caches\transforms-2\files-2.1\4c1ade53cc4b20d7bc631ac17d3bfca4\drawerlayout-1.0.0\AndroidManifest.xml:17:1-22:12
+MERGED from [androidx.slidingpanelayout:slidingpanelayout:1.0.0] C:\Users\\.gradle\caches\transforms-2\files-2.1\aa2f1cd22069a9bb65f1845d902d729f\slidingpanelayout-1.0.0\AndroidManifest.xml:17:1-22:12
+MERGED from [androidx.customview:customview:1.0.0] C:\Users\\.gradle\caches\transforms-2\files-2.1\d1ea25f3382273eed14315b543469208\customview-1.0.0\AndroidManifest.xml:17:1-22:12
+MERGED from [androidx.swiperefreshlayout:swiperefreshlayout:1.0.0] C:\Users\\.gradle\caches\transforms-2\files-2.1\a083b9190df6cd0b2eed1b8d83acb3d5\swiperefreshlayout-1.0.0\AndroidManifest.xml:17:1-22:12
+MERGED from [androidx.asynclayoutinflater:asynclayoutinflater:1.0.0] C:\Users\\.gradle\caches\transforms-2\files-2.1\f1f8381ec1e1c3f6b165a08612cfd883\asynclayoutinflater-1.0.0\AndroidManifest.xml:17:1-22:12
+MERGED from [androidx.core:core:1.0.0] C:\Users\\.gradle\caches\transforms-2\files-2.1\6d11613c3b6a00a9ea456b5609ec43f7\core-1.0.0\AndroidManifest.xml:17:1-24:12
+MERGED from [androidx.versionedparcelable:versionedparcelable:1.0.0] C:\Users\\.gradle\caches\transforms-2\files-2.1\5c19ca1a4638e9c78653f5d9bfebad33\versionedparcelable-1.0.0\AndroidManifest.xml:17:1-25:12
+MERGED from [androidx.lifecycle:lifecycle-runtime:2.0.0] C:\Users\\.gradle\caches\transforms-2\files-2.1\8bab031e716250a6a30588791dc60070\lifecycle-runtime-2.0.0\AndroidManifest.xml:17:1-22:12
+MERGED from [androidx.documentfile:documentfile:1.0.0] C:\Users\\.gradle\caches\transforms-2\files-2.1\7bcdab9edca68925f6bcb92ddd8a20de\documentfile-1.0.0\AndroidManifest.xml:17:1-22:12
+MERGED from [androidx.localbroadcastmanager:localbroadcastmanager:1.0.0] C:\Users\\.gradle\caches\transforms-2\files-2.1\d711f81259436f09ffdf0b48105165e3\localbroadcastmanager-1.0.0\AndroidManifest.xml:17:1-22:12
+MERGED from [androidx.print:print:1.0.0] C:\Users\\.gradle\caches\transforms-2\files-2.1\87e4a5cb4839ebd5d033fa0ae6227780\print-1.0.0\AndroidManifest.xml:17:1-22:12
+MERGED from [androidx.cursoradapter:cursoradapter:1.0.0] C:\Users\\.gradle\caches\transforms-2\files-2.1\7c0677be8011741026309ef690a9f4db\cursoradapter-1.0.0\AndroidManifest.xml:17:1-22:12
+MERGED from [androidx.interpolator:interpolator:1.0.0] C:\Users\\.gradle\caches\transforms-2\files-2.1\bcf856ddfeb04b3b73ed182739910d39\interpolator-1.0.0\AndroidManifest.xml:17:1-22:12
+MERGED from [androidx.lifecycle:lifecycle-viewmodel:2.0.0] C:\Users\\.gradle\caches\transforms-2\files-2.1\b42ab30b982239949a81eb93ceae6c0b\lifecycle-viewmodel-2.0.0\AndroidManifest.xml:17:1-22:12
+MERGED from [androidx.lifecycle:lifecycle-livedata:2.0.0] C:\Users\\.gradle\caches\transforms-2\files-2.1\c6f1e76c078a7e4f5288325854cab247\lifecycle-livedata-2.0.0\AndroidManifest.xml:17:1-22:12
+MERGED from [androidx.lifecycle:lifecycle-livedata-core:2.0.0] C:\Users\\.gradle\caches\transforms-2\files-2.1\7282e00d74c6a6acf53f4bfd68421266\lifecycle-livedata-core-2.0.0\AndroidManifest.xml:17:1-22:12
+MERGED from [androidx.arch.core:core-runtime:2.0.0] C:\Users\\.gradle\caches\transforms-2\files-2.1\73114719268a97e9fd391905563b2ee9\core-runtime-2.0.0\AndroidManifest.xml:17:1-22:12
+INJECTED from E:\Note\src\app\src\main\AndroidManifest.xml:18:1-166:12
+INJECTED from E:\Note\src\app\src\main\AndroidManifest.xml:18:1-166:12
+INJECTED from E:\Note\src\app\src\main\AndroidManifest.xml:18:1-166:12
+ package
+ ADDED from E:\Note\src\app\src\main\AndroidManifest.xml:19:5-31
+ INJECTED from E:\Note\src\app\src\main\AndroidManifest.xml
+ INJECTED from E:\Note\src\app\src\main\AndroidManifest.xml
+ android:versionName
+ ADDED from E:\Note\src\app\src\main\AndroidManifest.xml:22:5-30
+ INJECTED from E:\Note\src\app\src\main\AndroidManifest.xml
+ INJECTED from E:\Note\src\app\src\main\AndroidManifest.xml
+ android:targetSdkVersion
+ ADDED from E:\Note\src\app\src\main\AndroidManifest.xml:20:5-34
+ xmlns:android
+ ADDED from E:\Note\src\app\src\main\AndroidManifest.xml:18:11-69
+ android:versionCode
+ ADDED from E:\Note\src\app\src\main\AndroidManifest.xml:21:5-28
+ INJECTED from E:\Note\src\app\src\main\AndroidManifest.xml
+ INJECTED from E:\Note\src\app\src\main\AndroidManifest.xml
+uses-permission#android.permission.WRITE_EXTERNAL_STORAGE
+ADDED from E:\Note\src\app\src\main\AndroidManifest.xml:25:5-81
+ android:name
+ ADDED from E:\Note\src\app\src\main\AndroidManifest.xml:25:22-78
+uses-permission#com.android.launcher.permission.INSTALL_SHORTCUT
+ADDED from E:\Note\src\app\src\main\AndroidManifest.xml:26:5-88
+ android:name
+ ADDED from E:\Note\src\app\src\main\AndroidManifest.xml:26:22-85
+uses-permission#android.permission.INTERNET
+ADDED from E:\Note\src\app\src\main\AndroidManifest.xml:27:5-67
+ android:name
+ ADDED from E:\Note\src\app\src\main\AndroidManifest.xml:27:22-64
+uses-permission#android.permission.READ_CONTACTS
+ADDED from E:\Note\src\app\src\main\AndroidManifest.xml:28:5-72
+ android:name
+ ADDED from E:\Note\src\app\src\main\AndroidManifest.xml:28:22-69
+uses-permission#android.permission.MANAGE_ACCOUNTS
+ADDED from E:\Note\src\app\src\main\AndroidManifest.xml:29:5-74
+ android:name
+ ADDED from E:\Note\src\app\src\main\AndroidManifest.xml:29:22-71
+uses-permission#android.permission.AUTHENTICATE_ACCOUNTS
+ADDED from E:\Note\src\app\src\main\AndroidManifest.xml:30:5-80
+ android:name
+ ADDED from E:\Note\src\app\src\main\AndroidManifest.xml:30:22-77
+uses-permission#android.permission.GET_ACCOUNTS
+ADDED from E:\Note\src\app\src\main\AndroidManifest.xml:31:5-71
+ android:name
+ ADDED from E:\Note\src\app\src\main\AndroidManifest.xml:31:22-68
+uses-permission#android.permission.USE_CREDENTIALS
+ADDED from E:\Note\src\app\src\main\AndroidManifest.xml:32:5-74
+ android:name
+ ADDED from E:\Note\src\app\src\main\AndroidManifest.xml:32:22-71
+uses-permission#android.permission.RECEIVE_BOOT_COMPLETED
+ADDED from E:\Note\src\app\src\main\AndroidManifest.xml:33:5-81
+ android:name
+ ADDED from E:\Note\src\app\src\main\AndroidManifest.xml:33:22-78
+uses-permission#android.permission.RECORD_AUDIO
+ADDED from E:\Note\src\app\src\main\AndroidManifest.xml:34:5-70
+ android:name
+ ADDED from E:\Note\src\app\src\main\AndroidManifest.xml:34:22-68
+uses-permission#android.permission.ACCESS_FINE_LOCATION
+ADDED from E:\Note\src\app\src\main\AndroidManifest.xml:36:5-78
+ android:name
+ ADDED from E:\Note\src\app\src\main\AndroidManifest.xml:36:22-76
+uses-permission#android.permission.ACCESS_COARSE_LOCATION
+ADDED from E:\Note\src\app\src\main\AndroidManifest.xml:37:5-80
+ android:name
+ ADDED from E:\Note\src\app\src\main\AndroidManifest.xml:37:22-78
+application
+ADDED from E:\Note\src\app\src\main\AndroidManifest.xml:39:5-165:19
+MERGED from [androidx.core:core:1.0.0] C:\Users\\.gradle\caches\transforms-2\files-2.1\6d11613c3b6a00a9ea456b5609ec43f7\core-1.0.0\AndroidManifest.xml:22:5-89
+MERGED from [androidx.core:core:1.0.0] C:\Users\\.gradle\caches\transforms-2\files-2.1\6d11613c3b6a00a9ea456b5609ec43f7\core-1.0.0\AndroidManifest.xml:22:5-89
+MERGED from [androidx.versionedparcelable:versionedparcelable:1.0.0] C:\Users\\.gradle\caches\transforms-2\files-2.1\5c19ca1a4638e9c78653f5d9bfebad33\versionedparcelable-1.0.0\AndroidManifest.xml:22:5-23:19
+MERGED from [androidx.versionedparcelable:versionedparcelable:1.0.0] C:\Users\\.gradle\caches\transforms-2\files-2.1\5c19ca1a4638e9c78653f5d9bfebad33\versionedparcelable-1.0.0\AndroidManifest.xml:22:5-23:19
+ android:appComponentFactory
+ ADDED from [androidx.core:core:1.0.0] C:\Users\\.gradle\caches\transforms-2\files-2.1\6d11613c3b6a00a9ea456b5609ec43f7\core-1.0.0\AndroidManifest.xml:22:18-86
+ android:label
+ ADDED from E:\Note\src\app\src\main\AndroidManifest.xml:41:9-41
+ android:icon
+ ADDED from E:\Note\src\app\src\main\AndroidManifest.xml:40:9-42
+activity#net.micode.notes.ui.NotesListActivity
+ADDED from E:\Note\src\app\src\main\AndroidManifest.xml:42:9-55:20
+ android:label
+ ADDED from E:\Note\src\app\src\main\AndroidManifest.xml:45:13-45
+ android:launchMode
+ ADDED from E:\Note\src\app\src\main\AndroidManifest.xml:46:13-43
+ android:windowSoftInputMode
+ ADDED from E:\Note\src\app\src\main\AndroidManifest.xml:48:13-52
+ android:configChanges
+ ADDED from E:\Note\src\app\src\main\AndroidManifest.xml:44:13-74
+ android:theme
+ ADDED from E:\Note\src\app\src\main\AndroidManifest.xml:47:13-45
+ android:name
+ ADDED from E:\Note\src\app\src\main\AndroidManifest.xml:43:13-49
+intent-filter#action:name:android.intent.action.MAIN+category:name:android.intent.category.LAUNCHER
+ADDED from E:\Note\src\app\src\main\AndroidManifest.xml:50:13-53:29
+action#android.intent.action.MAIN
+ADDED from E:\Note\src\app\src\main\AndroidManifest.xml:51:17-69
+ android:name
+ ADDED from E:\Note\src\app\src\main\AndroidManifest.xml:51:25-66
+category#android.intent.category.LAUNCHER
+ADDED from E:\Note\src\app\src\main\AndroidManifest.xml:52:17-77
+ android:name
+ ADDED from E:\Note\src\app\src\main\AndroidManifest.xml:52:27-74
+activity#net.micode.notes.ui.NoteEditActivity
+ADDED from E:\Note\src\app\src\main\AndroidManifest.xml:57:9-85:20
+ android:launchMode
+ ADDED from E:\Note\src\app\src\main\AndroidManifest.xml:60:13-43
+ android:configChanges
+ ADDED from E:\Note\src\app\src\main\AndroidManifest.xml:59:13-74
+ android:theme
+ ADDED from E:\Note\src\app\src\main\AndroidManifest.xml:61:13-45
+ android:name
+ ADDED from E:\Note\src\app\src\main\AndroidManifest.xml:58:13-48
+intent-filter#action:name:android.intent.action.VIEW+category:name:android.intent.category.DEFAULT+data:mimeType:vnd.android.cursor.item/call_note+data:mimeType:vnd.android.cursor.item/text_note
+ADDED from E:\Note\src\app\src\main\AndroidManifest.xml:63:13-68:29
+action#android.intent.action.VIEW
+ADDED from E:\Note\src\app\src\main\AndroidManifest.xml:64:17-69
+ android:name
+ ADDED from E:\Note\src\app\src\main\AndroidManifest.xml:64:25-66
+category#android.intent.category.DEFAULT
+ADDED from E:\Note\src\app\src\main\AndroidManifest.xml:65:17-76
+ android:name
+ ADDED from E:\Note\src\app\src\main\AndroidManifest.xml:65:27-73
+data
+ADDED from E:\Note\src\app\src\main\AndroidManifest.xml:66:17-78
+ android:mimeType
+ ADDED from E:\Note\src\app\src\main\AndroidManifest.xml:66:23-75
+intent-filter#action:name:android.intent.action.INSERT_OR_EDIT+category:name:android.intent.category.DEFAULT+data:mimeType:vnd.android.cursor.item/call_note+data:mimeType:vnd.android.cursor.item/text_note
+ADDED from E:\Note\src\app\src\main\AndroidManifest.xml:70:13-75:29
+action#android.intent.action.INSERT_OR_EDIT
+ADDED from E:\Note\src\app\src\main\AndroidManifest.xml:71:17-79
+ android:name
+ ADDED from E:\Note\src\app\src\main\AndroidManifest.xml:71:25-76
+intent-filter#action:name:android.intent.action.SEARCH+category:name:android.intent.category.DEFAULT
+ADDED from E:\Note\src\app\src\main\AndroidManifest.xml:77:13-80:29
+action#android.intent.action.SEARCH
+ADDED from E:\Note\src\app\src\main\AndroidManifest.xml:78:17-71
+ android:name
+ ADDED from E:\Note\src\app\src\main\AndroidManifest.xml:78:25-68
+meta-data#android.app.searchable
+ADDED from E:\Note\src\app\src\main\AndroidManifest.xml:82:13-84:54
+ android:resource
+ ADDED from E:\Note\src\app\src\main\AndroidManifest.xml:84:17-51
+ android:name
+ ADDED from E:\Note\src\app\src\main\AndroidManifest.xml:83:17-54
+provider#net.micode.notes.data.NotesProvider
+ADDED from E:\Note\src\app\src\main\AndroidManifest.xml:87:9-90:43
+ android:authorities
+ ADDED from E:\Note\src\app\src\main\AndroidManifest.xml:89:13-47
+ android:multiprocess
+ ADDED from E:\Note\src\app\src\main\AndroidManifest.xml:90:13-40
+ android:name
+ ADDED from E:\Note\src\app\src\main\AndroidManifest.xml:88:13-63
+receiver#net.micode.notes.widget.NoteWidgetProvider_2x
+ADDED from E:\Note\src\app\src\main\AndroidManifest.xml:92:9-104:20
+ android:label
+ ADDED from E:\Note\src\app\src\main\AndroidManifest.xml:94:13-50
+ android:name
+ ADDED from E:\Note\src\app\src\main\AndroidManifest.xml:93:13-57
+intent-filter#action:name:android.appwidget.action.APPWIDGET_DELETED+action:name:android.appwidget.action.APPWIDGET_UPDATE+action:name:android.intent.action.PRIVACY_MODE_CHANGED
+ADDED from E:\Note\src\app\src\main\AndroidManifest.xml:95:13-99:29
+action#android.appwidget.action.APPWIDGET_UPDATE
+ADDED from E:\Note\src\app\src\main\AndroidManifest.xml:96:17-84
+ android:name
+ ADDED from E:\Note\src\app\src\main\AndroidManifest.xml:96:25-81
+action#android.appwidget.action.APPWIDGET_DELETED
+ADDED from E:\Note\src\app\src\main\AndroidManifest.xml:97:17-85
+ android:name
+ ADDED from E:\Note\src\app\src\main\AndroidManifest.xml:97:25-82
+action#android.intent.action.PRIVACY_MODE_CHANGED
+ADDED from E:\Note\src\app\src\main\AndroidManifest.xml:98:17-85
+ android:name
+ ADDED from E:\Note\src\app\src\main\AndroidManifest.xml:98:25-82
+meta-data#android.appwidget.provider
+ADDED from E:\Note\src\app\src\main\AndroidManifest.xml:101:13-103:58
+ android:resource
+ ADDED from E:\Note\src\app\src\main\AndroidManifest.xml:103:17-55
+ android:name
+ ADDED from E:\Note\src\app\src\main\AndroidManifest.xml:102:17-58
+receiver#net.micode.notes.widget.NoteWidgetProvider_4x
+ADDED from E:\Note\src\app\src\main\AndroidManifest.xml:105:9-118:20
+ android:label
+ ADDED from E:\Note\src\app\src\main\AndroidManifest.xml:107:13-50
+ android:name
+ ADDED from E:\Note\src\app\src\main\AndroidManifest.xml:106:13-57
+receiver#net.micode.notes.ui.AlarmInitReceiver
+ADDED from E:\Note\src\app\src\main\AndroidManifest.xml:120:9-124:20
+ android:name
+ ADDED from E:\Note\src\app\src\main\AndroidManifest.xml:120:19-55
+intent-filter#action:name:android.intent.action.BOOT_COMPLETED
+ADDED from E:\Note\src\app\src\main\AndroidManifest.xml:121:13-123:29
+action#android.intent.action.BOOT_COMPLETED
+ADDED from E:\Note\src\app\src\main\AndroidManifest.xml:122:17-79
+ android:name
+ ADDED from E:\Note\src\app\src\main\AndroidManifest.xml:122:25-76
+receiver#net.micode.notes.ui.AlarmReceiver
+ADDED from E:\Note\src\app\src\main\AndroidManifest.xml:126:9-129:20
+ android:process
+ ADDED from E:\Note\src\app\src\main\AndroidManifest.xml:128:13-38
+ android:name
+ ADDED from E:\Note\src\app\src\main\AndroidManifest.xml:127:13-61
+activity#net.micode.notes.ui.AlarmAlertActivity
+ADDED from E:\Note\src\app\src\main\AndroidManifest.xml:131:9-136:20
+ android:label
+ ADDED from E:\Note\src\app\src\main\AndroidManifest.xml:133:13-45
+ android:launchMode
+ ADDED from E:\Note\src\app\src\main\AndroidManifest.xml:134:13-48
+ android:theme
+ ADDED from E:\Note\src\app\src\main\AndroidManifest.xml:135:13-75
+ android:name
+ ADDED from E:\Note\src\app\src\main\AndroidManifest.xml:132:13-50
+activity#net.micode.notes.ui.MyBoard
+ADDED from E:\Note\src\app\src\main\AndroidManifest.xml:137:9-142:20
+ android:label
+ ADDED from E:\Note\src\app\src\main\AndroidManifest.xml:139:13-36
+ android:launchMode
+ ADDED from E:\Note\src\app\src\main\AndroidManifest.xml:140:13-48
+ android:theme
+ ADDED from E:\Note\src\app\src\main\AndroidManifest.xml:141:13-75
+ android:name
+ ADDED from E:\Note\src\app\src\main\AndroidManifest.xml:138:13-39
+activity#net.micode.notes.ui.GestureSetting
+ADDED from E:\Note\src\app\src\main\AndroidManifest.xml:143:9-148:20
+ android:label
+ ADDED from E:\Note\src\app\src\main\AndroidManifest.xml:145:13-43
+ android:launchMode
+ ADDED from E:\Note\src\app\src\main\AndroidManifest.xml:146:13-48
+ android:theme
+ ADDED from E:\Note\src\app\src\main\AndroidManifest.xml:147:13-75
+ android:name
+ ADDED from E:\Note\src\app\src\main\AndroidManifest.xml:144:13-46
+activity#net.micode.notes.ui.NotesPreferenceActivity
+ADDED from E:\Note\src\app\src\main\AndroidManifest.xml:150:9-155:20
+ android:label
+ ADDED from E:\Note\src\app\src\main\AndroidManifest.xml:152:13-54
+ android:launchMode
+ ADDED from E:\Note\src\app\src\main\AndroidManifest.xml:153:13-43
+ android:theme
+ ADDED from E:\Note\src\app\src\main\AndroidManifest.xml:154:13-60
+ android:name
+ ADDED from E:\Note\src\app\src\main\AndroidManifest.xml:151:13-71
+service#net.micode.notes.gtask.remote.GTaskSyncService
+ADDED from E:\Note\src\app\src\main\AndroidManifest.xml:157:9-160:19
+ android:exported
+ ADDED from E:\Note\src\app\src\main\AndroidManifest.xml:159:13-37
+ android:name
+ ADDED from E:\Note\src\app\src\main\AndroidManifest.xml:158:13-74
+meta-data#android.app.default_searchable
+ADDED from E:\Note\src\app\src\main\AndroidManifest.xml:162:9-164:52
+ android:value
+ ADDED from E:\Note\src\app\src\main\AndroidManifest.xml:164:13-49
+ android:name
+ ADDED from E:\Note\src\app\src\main\AndroidManifest.xml:163:13-58
+uses-sdk
+INJECTED from E:\Note\src\app\src\main\AndroidManifest.xml reason: use-sdk injection requested
+INJECTED from E:\Note\src\app\src\main\AndroidManifest.xml
+INJECTED from E:\Note\src\app\src\main\AndroidManifest.xml
+MERGED from [androidx.legacy:legacy-support-v4:1.0.0] C:\Users\\.gradle\caches\transforms-2\files-2.1\be0f08ddbc7b2ceb9beb29e6b731c207\legacy-support-v4-1.0.0\AndroidManifest.xml:20:5-44
+MERGED from [androidx.legacy:legacy-support-v4:1.0.0] C:\Users\\.gradle\caches\transforms-2\files-2.1\be0f08ddbc7b2ceb9beb29e6b731c207\legacy-support-v4-1.0.0\AndroidManifest.xml:20:5-44
+MERGED from [androidx.appcompat:appcompat:1.0.0-alpha1] C:\Users\\.gradle\caches\transforms-2\files-2.1\88c548461109b0c917067cfea58751b3\appcompat-1.0.0-alpha1\AndroidManifest.xml:20:5-44
+MERGED from [androidx.appcompat:appcompat:1.0.0-alpha1] C:\Users\\.gradle\caches\transforms-2\files-2.1\88c548461109b0c917067cfea58751b3\appcompat-1.0.0-alpha1\AndroidManifest.xml:20:5-44
+MERGED from [androidx.media:media:1.0.0] C:\Users\\.gradle\caches\transforms-2\files-2.1\702974eead929cb167f132efe0eabb04\media-1.0.0\AndroidManifest.xml:20:5-44
+MERGED from [androidx.media:media:1.0.0] C:\Users\\.gradle\caches\transforms-2\files-2.1\702974eead929cb167f132efe0eabb04\media-1.0.0\AndroidManifest.xml:20:5-44
+MERGED from [androidx.fragment:fragment:1.0.0] C:\Users\\.gradle\caches\transforms-2\files-2.1\bbcbf6e10ae52a08d3f4cdfbe738c39d\fragment-1.0.0\AndroidManifest.xml:20:5-44
+MERGED from [androidx.fragment:fragment:1.0.0] C:\Users\\.gradle\caches\transforms-2\files-2.1\bbcbf6e10ae52a08d3f4cdfbe738c39d\fragment-1.0.0\AndroidManifest.xml:20:5-44
+MERGED from [androidx.vectordrawable:vectordrawable-animated:1.0.0-alpha1] C:\Users\\.gradle\caches\transforms-2\files-2.1\a7af7f043769db5be0b091cfc45cc012\vectordrawable-animated-1.0.0-alpha1\AndroidManifest.xml:20:5-44
+MERGED from [androidx.vectordrawable:vectordrawable-animated:1.0.0-alpha1] C:\Users\\.gradle\caches\transforms-2\files-2.1\a7af7f043769db5be0b091cfc45cc012\vectordrawable-animated-1.0.0-alpha1\AndroidManifest.xml:20:5-44
+MERGED from [androidx.legacy:legacy-support-core-ui:1.0.0] C:\Users\\.gradle\caches\transforms-2\files-2.1\f5ec57ec49d0a3e9add695de66a9078c\legacy-support-core-ui-1.0.0\AndroidManifest.xml:20:5-44
+MERGED from [androidx.legacy:legacy-support-core-ui:1.0.0] C:\Users\\.gradle\caches\transforms-2\files-2.1\f5ec57ec49d0a3e9add695de66a9078c\legacy-support-core-ui-1.0.0\AndroidManifest.xml:20:5-44
+MERGED from [androidx.legacy:legacy-support-core-utils:1.0.0] C:\Users\\.gradle\caches\transforms-2\files-2.1\18f5c1f0dcc08504bb6a1709d838cf6b\legacy-support-core-utils-1.0.0\AndroidManifest.xml:20:5-44
+MERGED from [androidx.legacy:legacy-support-core-utils:1.0.0] C:\Users\\.gradle\caches\transforms-2\files-2.1\18f5c1f0dcc08504bb6a1709d838cf6b\legacy-support-core-utils-1.0.0\AndroidManifest.xml:20:5-44
+MERGED from [androidx.vectordrawable:vectordrawable:1.0.0-alpha1] C:\Users\\.gradle\caches\transforms-2\files-2.1\3c5008756363749b06d8984591aefc49\vectordrawable-1.0.0-alpha1\AndroidManifest.xml:20:5-44
+MERGED from [androidx.vectordrawable:vectordrawable:1.0.0-alpha1] C:\Users\\.gradle\caches\transforms-2\files-2.1\3c5008756363749b06d8984591aefc49\vectordrawable-1.0.0-alpha1\AndroidManifest.xml:20:5-44
+MERGED from [androidx.loader:loader:1.0.0] C:\Users\\.gradle\caches\transforms-2\files-2.1\2118a7099009bdd29f0289728ee82c0d\loader-1.0.0\AndroidManifest.xml:20:5-44
+MERGED from [androidx.loader:loader:1.0.0] C:\Users\\.gradle\caches\transforms-2\files-2.1\2118a7099009bdd29f0289728ee82c0d\loader-1.0.0\AndroidManifest.xml:20:5-44
+MERGED from [androidx.viewpager:viewpager:1.0.0] C:\Users\\.gradle\caches\transforms-2\files-2.1\ebc8011c39d26c440b76466a9b971345\viewpager-1.0.0\AndroidManifest.xml:20:5-44
+MERGED from [androidx.viewpager:viewpager:1.0.0] C:\Users\\.gradle\caches\transforms-2\files-2.1\ebc8011c39d26c440b76466a9b971345\viewpager-1.0.0\AndroidManifest.xml:20:5-44
+MERGED from [androidx.coordinatorlayout:coordinatorlayout:1.0.0] C:\Users\\.gradle\caches\transforms-2\files-2.1\df8a19ef163eaa8f3d3c8f24458897fd\coordinatorlayout-1.0.0\AndroidManifest.xml:20:5-44
+MERGED from [androidx.coordinatorlayout:coordinatorlayout:1.0.0] C:\Users\\.gradle\caches\transforms-2\files-2.1\df8a19ef163eaa8f3d3c8f24458897fd\coordinatorlayout-1.0.0\AndroidManifest.xml:20:5-44
+MERGED from [androidx.drawerlayout:drawerlayout:1.0.0] C:\Users\\.gradle\caches\transforms-2\files-2.1\4c1ade53cc4b20d7bc631ac17d3bfca4\drawerlayout-1.0.0\AndroidManifest.xml:20:5-44
+MERGED from [androidx.drawerlayout:drawerlayout:1.0.0] C:\Users\\.gradle\caches\transforms-2\files-2.1\4c1ade53cc4b20d7bc631ac17d3bfca4\drawerlayout-1.0.0\AndroidManifest.xml:20:5-44
+MERGED from [androidx.slidingpanelayout:slidingpanelayout:1.0.0] C:\Users\\.gradle\caches\transforms-2\files-2.1\aa2f1cd22069a9bb65f1845d902d729f\slidingpanelayout-1.0.0\AndroidManifest.xml:20:5-44
+MERGED from [androidx.slidingpanelayout:slidingpanelayout:1.0.0] C:\Users\\.gradle\caches\transforms-2\files-2.1\aa2f1cd22069a9bb65f1845d902d729f\slidingpanelayout-1.0.0\AndroidManifest.xml:20:5-44
+MERGED from [androidx.customview:customview:1.0.0] C:\Users\\.gradle\caches\transforms-2\files-2.1\d1ea25f3382273eed14315b543469208\customview-1.0.0\AndroidManifest.xml:20:5-44
+MERGED from [androidx.customview:customview:1.0.0] C:\Users\\.gradle\caches\transforms-2\files-2.1\d1ea25f3382273eed14315b543469208\customview-1.0.0\AndroidManifest.xml:20:5-44
+MERGED from [androidx.swiperefreshlayout:swiperefreshlayout:1.0.0] C:\Users\\.gradle\caches\transforms-2\files-2.1\a083b9190df6cd0b2eed1b8d83acb3d5\swiperefreshlayout-1.0.0\AndroidManifest.xml:20:5-44
+MERGED from [androidx.swiperefreshlayout:swiperefreshlayout:1.0.0] C:\Users\\.gradle\caches\transforms-2\files-2.1\a083b9190df6cd0b2eed1b8d83acb3d5\swiperefreshlayout-1.0.0\AndroidManifest.xml:20:5-44
+MERGED from [androidx.asynclayoutinflater:asynclayoutinflater:1.0.0] C:\Users\\.gradle\caches\transforms-2\files-2.1\f1f8381ec1e1c3f6b165a08612cfd883\asynclayoutinflater-1.0.0\AndroidManifest.xml:20:5-44
+MERGED from [androidx.asynclayoutinflater:asynclayoutinflater:1.0.0] C:\Users\\.gradle\caches\transforms-2\files-2.1\f1f8381ec1e1c3f6b165a08612cfd883\asynclayoutinflater-1.0.0\AndroidManifest.xml:20:5-44
+MERGED from [androidx.core:core:1.0.0] C:\Users\\.gradle\caches\transforms-2\files-2.1\6d11613c3b6a00a9ea456b5609ec43f7\core-1.0.0\AndroidManifest.xml:20:5-44
+MERGED from [androidx.core:core:1.0.0] C:\Users\\.gradle\caches\transforms-2\files-2.1\6d11613c3b6a00a9ea456b5609ec43f7\core-1.0.0\AndroidManifest.xml:20:5-44
+MERGED from [androidx.versionedparcelable:versionedparcelable:1.0.0] C:\Users\\.gradle\caches\transforms-2\files-2.1\5c19ca1a4638e9c78653f5d9bfebad33\versionedparcelable-1.0.0\AndroidManifest.xml:20:5-44
+MERGED from [androidx.versionedparcelable:versionedparcelable:1.0.0] C:\Users\\.gradle\caches\transforms-2\files-2.1\5c19ca1a4638e9c78653f5d9bfebad33\versionedparcelable-1.0.0\AndroidManifest.xml:20:5-44
+MERGED from [androidx.lifecycle:lifecycle-runtime:2.0.0] C:\Users\\.gradle\caches\transforms-2\files-2.1\8bab031e716250a6a30588791dc60070\lifecycle-runtime-2.0.0\AndroidManifest.xml:20:5-44
+MERGED from [androidx.lifecycle:lifecycle-runtime:2.0.0] C:\Users\\.gradle\caches\transforms-2\files-2.1\8bab031e716250a6a30588791dc60070\lifecycle-runtime-2.0.0\AndroidManifest.xml:20:5-44
+MERGED from [androidx.documentfile:documentfile:1.0.0] C:\Users\\.gradle\caches\transforms-2\files-2.1\7bcdab9edca68925f6bcb92ddd8a20de\documentfile-1.0.0\AndroidManifest.xml:20:5-44
+MERGED from [androidx.documentfile:documentfile:1.0.0] C:\Users\\.gradle\caches\transforms-2\files-2.1\7bcdab9edca68925f6bcb92ddd8a20de\documentfile-1.0.0\AndroidManifest.xml:20:5-44
+MERGED from [androidx.localbroadcastmanager:localbroadcastmanager:1.0.0] C:\Users\\.gradle\caches\transforms-2\files-2.1\d711f81259436f09ffdf0b48105165e3\localbroadcastmanager-1.0.0\AndroidManifest.xml:20:5-44
+MERGED from [androidx.localbroadcastmanager:localbroadcastmanager:1.0.0] C:\Users\\.gradle\caches\transforms-2\files-2.1\d711f81259436f09ffdf0b48105165e3\localbroadcastmanager-1.0.0\AndroidManifest.xml:20:5-44
+MERGED from [androidx.print:print:1.0.0] C:\Users\\.gradle\caches\transforms-2\files-2.1\87e4a5cb4839ebd5d033fa0ae6227780\print-1.0.0\AndroidManifest.xml:20:5-44
+MERGED from [androidx.print:print:1.0.0] C:\Users\\.gradle\caches\transforms-2\files-2.1\87e4a5cb4839ebd5d033fa0ae6227780\print-1.0.0\AndroidManifest.xml:20:5-44
+MERGED from [androidx.cursoradapter:cursoradapter:1.0.0] C:\Users\\.gradle\caches\transforms-2\files-2.1\7c0677be8011741026309ef690a9f4db\cursoradapter-1.0.0\AndroidManifest.xml:20:5-44
+MERGED from [androidx.cursoradapter:cursoradapter:1.0.0] C:\Users\\.gradle\caches\transforms-2\files-2.1\7c0677be8011741026309ef690a9f4db\cursoradapter-1.0.0\AndroidManifest.xml:20:5-44
+MERGED from [androidx.interpolator:interpolator:1.0.0] C:\Users\\.gradle\caches\transforms-2\files-2.1\bcf856ddfeb04b3b73ed182739910d39\interpolator-1.0.0\AndroidManifest.xml:20:5-44
+MERGED from [androidx.interpolator:interpolator:1.0.0] C:\Users\\.gradle\caches\transforms-2\files-2.1\bcf856ddfeb04b3b73ed182739910d39\interpolator-1.0.0\AndroidManifest.xml:20:5-44
+MERGED from [androidx.lifecycle:lifecycle-viewmodel:2.0.0] C:\Users\\.gradle\caches\transforms-2\files-2.1\b42ab30b982239949a81eb93ceae6c0b\lifecycle-viewmodel-2.0.0\AndroidManifest.xml:20:5-44
+MERGED from [androidx.lifecycle:lifecycle-viewmodel:2.0.0] C:\Users\\.gradle\caches\transforms-2\files-2.1\b42ab30b982239949a81eb93ceae6c0b\lifecycle-viewmodel-2.0.0\AndroidManifest.xml:20:5-44
+MERGED from [androidx.lifecycle:lifecycle-livedata:2.0.0] C:\Users\\.gradle\caches\transforms-2\files-2.1\c6f1e76c078a7e4f5288325854cab247\lifecycle-livedata-2.0.0\AndroidManifest.xml:20:5-44
+MERGED from [androidx.lifecycle:lifecycle-livedata:2.0.0] C:\Users\\.gradle\caches\transforms-2\files-2.1\c6f1e76c078a7e4f5288325854cab247\lifecycle-livedata-2.0.0\AndroidManifest.xml:20:5-44
+MERGED from [androidx.lifecycle:lifecycle-livedata-core:2.0.0] C:\Users\\.gradle\caches\transforms-2\files-2.1\7282e00d74c6a6acf53f4bfd68421266\lifecycle-livedata-core-2.0.0\AndroidManifest.xml:20:5-44
+MERGED from [androidx.lifecycle:lifecycle-livedata-core:2.0.0] C:\Users\\.gradle\caches\transforms-2\files-2.1\7282e00d74c6a6acf53f4bfd68421266\lifecycle-livedata-core-2.0.0\AndroidManifest.xml:20:5-44
+MERGED from [androidx.arch.core:core-runtime:2.0.0] C:\Users\\.gradle\caches\transforms-2\files-2.1\73114719268a97e9fd391905563b2ee9\core-runtime-2.0.0\AndroidManifest.xml:20:5-44
+MERGED from [androidx.arch.core:core-runtime:2.0.0] C:\Users\\.gradle\caches\transforms-2\files-2.1\73114719268a97e9fd391905563b2ee9\core-runtime-2.0.0\AndroidManifest.xml:20:5-44
+INJECTED from E:\Note\src\app\src\main\AndroidManifest.xml
+INJECTED from E:\Note\src\app\src\main\AndroidManifest.xml
+ android:targetSdkVersion
+ INJECTED from E:\Note\src\app\src\main\AndroidManifest.xml
+ ADDED from E:\Note\src\app\src\main\AndroidManifest.xml
+ INJECTED from E:\Note\src\app\src\main\AndroidManifest.xml
+ android:minSdkVersion
+ INJECTED from E:\Note\src\app\src\main\AndroidManifest.xml
+ ADDED from E:\Note\src\app\src\main\AndroidManifest.xml
+ INJECTED from E:\Note\src\app\src\main\AndroidManifest.xml
diff --git a/src/src/app/src/main/AndroidManifest.xml b/src/src/app/src/main/AndroidManifest.xml
new file mode 100644
index 0000000..865e1b4
--- /dev/null
+++ b/src/src/app/src/main/AndroidManifest.xml
@@ -0,0 +1,166 @@
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
diff --git a/src/src/app/src/main/java/net/micode/notes/data/Contact.java b/src/src/app/src/main/java/net/micode/notes/data/Contact.java
new file mode 100644
index 0000000..d97ac5d
--- /dev/null
+++ b/src/src/app/src/main/java/net/micode/notes/data/Contact.java
@@ -0,0 +1,73 @@
+/*
+ * Copyright (c) 2010-2011, The MiCode Open Source Community (www.micode.net)
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+
+package net.micode.notes.data;
+
+import android.content.Context;
+import android.database.Cursor;
+import android.provider.ContactsContract.CommonDataKinds.Phone;
+import android.provider.ContactsContract.Data;
+import android.telephony.PhoneNumberUtils;
+import android.util.Log;
+
+import java.util.HashMap;
+
+public class Contact {
+ private static HashMap sContactCache;
+ private static final String TAG = "Contact";
+
+ private static final String CALLER_ID_SELECTION = "PHONE_NUMBERS_EQUAL(" + Phone.NUMBER
+ + ",?) AND " + Data.MIMETYPE + "='" + Phone.CONTENT_ITEM_TYPE + "'"
+ + " AND " + Data.RAW_CONTACT_ID + " IN "
+ + "(SELECT raw_contact_id "
+ + " FROM phone_lookup"
+ + " WHERE min_match = '+')";
+
+ public static String getContact(Context context, String phoneNumber) {
+ if(sContactCache == null) {
+ sContactCache = new HashMap();
+ }
+
+ if(sContactCache.containsKey(phoneNumber)) {
+ return sContactCache.get(phoneNumber);
+ }
+
+ String selection = CALLER_ID_SELECTION.replace("+",
+ PhoneNumberUtils.toCallerIDMinMatch(phoneNumber));
+ Cursor cursor = context.getContentResolver().query(
+ Data.CONTENT_URI,
+ new String [] { Phone.DISPLAY_NAME },
+ selection,
+ new String[] { phoneNumber },
+ null);
+
+ if (cursor != null && cursor.moveToFirst()) {
+ try {
+ String name = cursor.getString(0);
+ sContactCache.put(phoneNumber, name);
+ return name;
+ } catch (IndexOutOfBoundsException e) {
+ Log.e(TAG, " Cursor get string error " + e.toString());
+ return null;
+ } finally {
+ cursor.close();
+ }
+ } else {
+ Log.d(TAG, "No contact matched with number:" + phoneNumber);
+ return null;
+ }
+ }
+}
diff --git a/src/src/app/src/main/java/net/micode/notes/data/Notes.java b/src/src/app/src/main/java/net/micode/notes/data/Notes.java
new file mode 100644
index 0000000..eb908df
--- /dev/null
+++ b/src/src/app/src/main/java/net/micode/notes/data/Notes.java
@@ -0,0 +1,286 @@
+/*
+ * Copyright (c) 2010-2011, The MiCode Open Source Community (www.micode.net)
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+
+package net.micode.notes.data;
+
+import android.net.Uri;
+public class Notes {
+ public static final String AUTHORITY = "micode_notes";
+ public static final String TAG = "Notes";
+ public static final int TYPE_NOTE = 0;
+ public static final int TYPE_FOLDER = 1;
+ public static final int TYPE_SYSTEM = 2;
+
+ /**
+ * Following IDs are system folders' identifiers
+ * {@link Notes#ID_ROOT_FOLDER } is default folder
+ * {@link Notes#ID_TEMPARAY_FOLDER } is for notes belonging no folder
+ * {@link Notes#ID_CALL_RECORD_FOLDER} is to store call records
+ */
+ public static final int ID_ROOT_FOLDER = 0;
+ public static final int ID_TEMPARAY_FOLDER = -1;
+ public static final int ID_CALL_RECORD_FOLDER = -2;
+ public static final int ID_TRASH_FOLER = -3;
+
+ public static final String INTENT_EXTRA_ALERT_DATE = "net.micode.notes.alert_date";
+ public static final String INTENT_EXTRA_BACKGROUND_ID = "net.micode.notes.background_color_id";
+ public static final String INTENT_EXTRA_WIDGET_ID = "net.micode.notes.widget_id";
+ public static final String INTENT_EXTRA_WIDGET_TYPE = "net.micode.notes.widget_type";
+ public static final String INTENT_EXTRA_FOLDER_ID = "net.micode.notes.folder_id";
+ public static final String INTENT_EXTRA_CALL_DATE = "net.micode.notes.call_date";
+
+ public static final int TYPE_WIDGET_INVALIDE = -1;
+ public static final int TYPE_WIDGET_2X = 0;
+ public static final int TYPE_WIDGET_4X = 1;
+ public static final String Content = "content://" ;
+ public static class DataConstants {
+ public static final String NOTE = TextNote.CONTENT_ITEM_TYPE;
+ public static final String CALL_NOTE = CallNote.CONTENT_ITEM_TYPE;
+ }
+
+ /**
+ * Uri to query all notes and folders
+ */
+ public static final Uri CONTENT_NOTE_URI = Uri.parse(Content + AUTHORITY + "/note");
+
+ /**
+ * Uri to query data
+ */
+ public static final Uri CONTENT_DATA_URI = Uri.parse(Content + AUTHORITY + "/data");
+
+ public interface NoteColumns {
+
+ //mine 2
+ String HINT = "hint";
+ String PASSWORD = "note_password";
+ /**
+ * The unique ID for a row
+ *
Type: INTEGER (long)
+ */
+ String ID = "_id";
+
+ /**
+ * The parent's id for note or folder
+ *
Type: INTEGER (long)
+ */
+ String PARENT_ID = "parent_id";
+
+ /**
+ * Created data for note or folder
+ *
+ */
+ String BG_COLOR_ID = "bg_color_id";
+
+ /**
+ * For text note, it doesn't has attachment, for multi-media
+ * note, it has at least one attachment
+ *
+ */
+ String CONTENT = "content";
+
+
+ /**
+ * Generic data column, the meaning is specific, used for
+ * integer data type
+ *
Type: INTEGER
+ */
+ String DATA1 = "data1";
+
+ /**
+ * Generic data column, the meaning is specific, used for
+ * integer data type
+ *
Type: INTEGER
+ */
+ String DATA2 = "data2";
+
+ /**
+ * Generic data column, the meaning is specific, used for
+ * TEXT data type
+ *
Type: TEXT
+ */
+ String DATA3 = "data3";
+
+ /**
+ * Generic data column, the meaning is specific, used for
+ * TEXT data type
+ *
Type: TEXT
+ */
+ String DATA4 = "data4";
+
+ /**
+ * Generic data column, the meaning is specific, used for
+ * TEXT data type
+ *
Type: TEXT
+ */
+ String DATA5 = "data5";
+ }
+
+ public static final class TextNote implements DataColumns {
+ /**
+ * Mode to indicate the text in check list mode or not
+ *
Type: Integer 1:check list mode 0: normal mode
+ */
+ public static final String MODE = DATA1;
+
+ public static final int MODE_CHECK_LIST = 1;
+
+ public static final int MODE_PRIVATE_TYPE = 2;//隐私模式,加密码 mine 1 这里留了一个bug,就是清单模式和私密便签模式同时使用了一个变量储存,懒得改了。。。。。
+
+
+ public static final String CONTENT_TYPE = "vnd.android.cursor.dir/text_note";
+
+ public static final String CONTENT_ITEM_TYPE = "vnd.android.cursor.item/text_note";
+
+ public static final Uri CONTENT_URI = Uri.parse(Content + AUTHORITY + "/text_note");
+ }
+
+ public static final class CallNote implements DataColumns {
+ /**
+ * Call date for this record
+ *
Type: INTEGER (long)
+ */
+ public static final String CALL_DATE = DATA1;
+
+ /**
+ * Phone number for this record
+ *
Type: TEXT
+ */
+ public static final String PHONE_NUMBER = DATA3;
+
+ public static final String CONTENT_TYPE = "vnd.android.cursor.dir/call_note";
+
+ public static final String CONTENT_ITEM_TYPE = "vnd.android.cursor.item/call_note";
+
+ public static final Uri CONTENT_URI = Uri.parse(Content + AUTHORITY + "/call_note");
+ }
+}
diff --git a/src/src/app/src/main/java/net/micode/notes/data/NotesDatabaseHelper.java b/src/src/app/src/main/java/net/micode/notes/data/NotesDatabaseHelper.java
new file mode 100644
index 0000000..0838bf4
--- /dev/null
+++ b/src/src/app/src/main/java/net/micode/notes/data/NotesDatabaseHelper.java
@@ -0,0 +1,384 @@
+/*
+ * Copyright (c) 2010-2011, The MiCode Open Source Community (www.micode.net)
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+
+package net.micode.notes.data;
+
+import android.content.ContentValues;
+import android.content.Context;
+import android.database.Cursor;
+import android.database.sqlite.SQLiteDatabase;
+import android.database.sqlite.SQLiteOpenHelper;
+import android.util.Log;
+
+import net.micode.notes.data.Notes.DataColumns;
+import net.micode.notes.data.Notes.DataConstants;
+import net.micode.notes.data.Notes.NoteColumns;
+import net.micode.notes.ui.NoteItemData;
+
+
+public class NotesDatabaseHelper extends SQLiteOpenHelper {
+ private static final String DB_NAME = "note.db";
+
+ private static final int DB_VERSION = 4;
+
+ public interface TABLE {
+ String NOTE = "note";
+
+ String DATA = "data";
+ }
+
+ private static final String TAG = "NotesDatabaseHelper";
+
+ private static NotesDatabaseHelper mInstance;
+
+ private static final String CREATE_NOTE_TABLE_SQL =
+ "CREATE TABLE " + TABLE.NOTE + "(" +
+ NoteColumns.ID + " INTEGER PRIMARY KEY," +
+ NoteColumns.PARENT_ID + " INTEGER NOT NULL DEFAULT 0," +
+ NoteColumns.ALERTED_DATE + " INTEGER NOT NULL DEFAULT 0," +
+ NoteColumns.BG_COLOR_ID + " INTEGER NOT NULL DEFAULT 0," +
+ NoteColumns.CREATED_DATE + " INTEGER NOT NULL DEFAULT (strftime('%s','now') * 1000)," +
+ NoteColumns.HAS_ATTACHMENT + " INTEGER NOT NULL DEFAULT 0," +
+ NoteColumns.MODIFIED_DATE + " INTEGER NOT NULL DEFAULT (strftime('%s','now') * 1000)," +
+ NoteColumns.NOTES_COUNT + " INTEGER NOT NULL DEFAULT 0," +
+ NoteColumns.SNIPPET + " TEXT NOT NULL DEFAULT ''," +
+ NoteColumns.TYPE + " INTEGER NOT NULL DEFAULT 0," +
+ NoteColumns.WIDGET_ID + " INTEGER NOT NULL DEFAULT 0," +
+ NoteColumns.WIDGET_TYPE + " INTEGER NOT NULL DEFAULT -1," +
+ NoteColumns.SYNC_ID + " INTEGER NOT NULL DEFAULT 0," +
+ NoteColumns.LOCAL_MODIFIED + " INTEGER NOT NULL DEFAULT 0," +
+ NoteColumns.ORIGIN_PARENT_ID + " INTEGER NOT NULL DEFAULT 0," +
+ NoteColumns.GTASK_ID + " TEXT NOT NULL DEFAULT ''," +
+ NoteColumns.VERSION + " INTEGER NOT NULL DEFAULT 0," +
+ NoteColumns.PASSWORD + " TEXT NOT NULL DEFAULT ''," +//创建密码的表项
+ NoteColumns.HINT + " TEXT NOT NULL DEFAULT '' "+//创建密码提示的表项
+ ")";
+
+ private static final String CREATE_DATA_TABLE_SQL =
+ "CREATE TABLE " + TABLE.DATA + "(" +
+ DataColumns.ID + " INTEGER PRIMARY KEY," +
+ DataColumns.MIME_TYPE + " TEXT NOT NULL," +
+ DataColumns.NOTE_ID + " INTEGER NOT NULL DEFAULT 0," +
+ NoteColumns.CREATED_DATE + " INTEGER NOT NULL DEFAULT (strftime('%s','now') * 1000)," +
+ NoteColumns.MODIFIED_DATE + " INTEGER NOT NULL DEFAULT (strftime('%s','now') * 1000)," +
+ DataColumns.CONTENT + " TEXT NOT NULL DEFAULT ''," +
+ DataColumns.DATA1 + " INTEGER," +
+ DataColumns.DATA2 + " INTEGER," +
+ DataColumns.DATA3 + " TEXT NOT NULL DEFAULT ''," +
+ DataColumns.DATA4 + " TEXT NOT NULL DEFAULT ''," +
+ DataColumns.DATA5 + " TEXT NOT NULL DEFAULT ''" +
+ ")";
+
+ private static final String CREATE_DATA_NOTE_ID_INDEX_SQL =
+ "CREATE INDEX IF NOT EXISTS note_id_index ON " +
+ TABLE.DATA + "(" + DataColumns.NOTE_ID + ");";
+
+ /**
+ * Increase folder's note count when move note to the folder
+ */
+ private static final String NOTE_INCREASE_FOLDER_COUNT_ON_UPDATE_TRIGGER =
+ "CREATE TRIGGER increase_folder_count_on_update "+
+ " AFTER UPDATE OF " + NoteColumns.PARENT_ID + " ON " + TABLE.NOTE +
+ " BEGIN " +
+ " UPDATE " + TABLE.NOTE +
+ " SET " + NoteColumns.NOTES_COUNT + "=" + NoteColumns.NOTES_COUNT + " + 1" +
+ " WHERE " + NoteColumns.ID + "=new." + NoteColumns.PARENT_ID + ";" +
+ " END";
+
+ /**
+ * Decrease folder's note count when move note from folder
+ */
+ private static final String NOTE_DECREASE_FOLDER_COUNT_ON_UPDATE_TRIGGER =
+ "CREATE TRIGGER decrease_folder_count_on_update " +
+ " AFTER UPDATE OF " + NoteColumns.PARENT_ID + " ON " + TABLE.NOTE +
+ " BEGIN " +
+ " UPDATE " + TABLE.NOTE +
+ " SET " + NoteColumns.NOTES_COUNT + "=" + NoteColumns.NOTES_COUNT + "-1" +
+ " WHERE " + NoteColumns.ID + "=old." + NoteColumns.PARENT_ID +
+ " AND " + NoteColumns.NOTES_COUNT + ">0" + ";" +
+ " END";
+
+ /**
+ * Increase folder's note count when insert new note to the folder
+ */
+ private static final String NOTE_INCREASE_FOLDER_COUNT_ON_INSERT_TRIGGER =
+ "CREATE TRIGGER increase_folder_count_on_insert " +
+ " AFTER INSERT ON " + TABLE.NOTE +
+ " BEGIN " +
+ " UPDATE " + TABLE.NOTE +
+ " SET " + NoteColumns.NOTES_COUNT + "=" + NoteColumns.NOTES_COUNT + " + 1" +
+ " WHERE " + NoteColumns.ID + "=new." + NoteColumns.PARENT_ID + ";" +
+ " END";
+
+ /**
+ * Decrease folder's note count when delete note from the folder
+ */
+ private static final String NOTE_DECREASE_FOLDER_COUNT_ON_DELETE_TRIGGER =
+ "CREATE TRIGGER decrease_folder_count_on_delete " +
+ " AFTER DELETE ON " + TABLE.NOTE +
+ " BEGIN " +
+ " UPDATE " + TABLE.NOTE +
+ " SET " + NoteColumns.NOTES_COUNT + "=" + NoteColumns.NOTES_COUNT + "-1" +
+ " WHERE " + NoteColumns.ID + "=old." + NoteColumns.PARENT_ID +
+ " AND " + NoteColumns.NOTES_COUNT + ">0;" +
+ " END";
+
+ /**
+ * Update note's content when insert data with type {@link DataConstants#NOTE}
+ */
+ private static final String DATA_UPDATE_NOTE_CONTENT_ON_INSERT_TRIGGER =
+ "CREATE TRIGGER update_note_content_on_insert " +
+ " AFTER INSERT ON " + TABLE.DATA +
+ " WHEN new." + DataColumns.MIME_TYPE + "='" + DataConstants.NOTE + "'" +
+ " BEGIN" +
+ " UPDATE " + TABLE.NOTE +
+ " SET " + NoteColumns.SNIPPET + "=new." + DataColumns.CONTENT +
+ " WHERE " + NoteColumns.ID + "=new." + DataColumns.NOTE_ID + ";" +
+ " END";
+
+ /**
+ * Update note's content when data with {@link DataConstants#NOTE} type has changed
+ */
+ private static final String DATA_UPDATE_NOTE_CONTENT_ON_UPDATE_TRIGGER =
+ "CREATE TRIGGER update_note_content_on_update " +
+ " AFTER UPDATE ON " + TABLE.DATA +
+ " WHEN old." + DataColumns.MIME_TYPE + "='" + DataConstants.NOTE + "'" +
+ " BEGIN" +
+ " UPDATE " + TABLE.NOTE +
+ " SET " + NoteColumns.SNIPPET + "=new." + DataColumns.CONTENT +
+ " WHERE " + NoteColumns.ID + "=new." + DataColumns.NOTE_ID + ";" +
+ " END";
+
+ /**
+ * Update note's content when data with {@link DataConstants#NOTE} type has deleted
+ */
+ private static final String DATA_UPDATE_NOTE_CONTENT_ON_DELETE_TRIGGER =
+ "CREATE TRIGGER update_note_content_on_delete " +
+ " AFTER delete ON " + TABLE.DATA +
+ " WHEN old." + DataColumns.MIME_TYPE + "='" + DataConstants.NOTE + "'" +
+ " BEGIN" +
+ " UPDATE " + TABLE.NOTE +
+ " SET " + NoteColumns.SNIPPET + "=''" +
+ " WHERE " + NoteColumns.ID + "=old." + DataColumns.NOTE_ID + ";" +
+ " END";
+
+ /**
+ * Delete datas belong to note which has been deleted
+ */
+ private static final String NOTE_DELETE_DATA_ON_DELETE_TRIGGER =
+ "CREATE TRIGGER delete_data_on_delete " +
+ " AFTER DELETE ON " + TABLE.NOTE +
+ " BEGIN" +
+ " DELETE FROM " + TABLE.DATA +
+ " WHERE " + DataColumns.NOTE_ID + "=old." + NoteColumns.ID + ";" +
+ " END";
+
+ /**
+ * Delete notes belong to folder which has been deleted
+ */
+ private static final String FOLDER_DELETE_NOTES_ON_DELETE_TRIGGER =
+ "CREATE TRIGGER folder_delete_notes_on_delete " +
+ " AFTER DELETE ON " + TABLE.NOTE +
+ " BEGIN" +
+ " DELETE FROM " + TABLE.NOTE +
+ " WHERE " + NoteColumns.PARENT_ID + "=old." + NoteColumns.ID + ";" +
+ " END";
+
+ /**
+ * Move notes belong to folder which has been moved to trash folder
+ */
+ private static final String FOLDER_MOVE_NOTES_ON_TRASH_TRIGGER =
+ "CREATE TRIGGER folder_move_notes_on_trash " +
+ " AFTER UPDATE ON " + TABLE.NOTE +
+ " WHEN new." + NoteColumns.PARENT_ID + "=" + Notes.ID_TRASH_FOLER +
+ " BEGIN" +
+ " UPDATE " + TABLE.NOTE +
+ " SET " + NoteColumns.PARENT_ID + "=" + Notes.ID_TRASH_FOLER +
+ " WHERE " + NoteColumns.PARENT_ID + "=old." + NoteColumns.ID + ";" +
+ " END";
+
+ public NotesDatabaseHelper(Context context) {
+ super(context, DB_NAME, null, DB_VERSION);
+ }
+
+ public void createNoteTable(SQLiteDatabase db) {
+ db.execSQL(CREATE_NOTE_TABLE_SQL);
+ reCreateNoteTableTriggers(db);
+ createSystemFolder(db);
+ Log.d(TAG, "note table has been created");
+ }
+
+ private void reCreateNoteTableTriggers(SQLiteDatabase db) {
+ db.execSQL("DROP TRIGGER IF EXISTS increase_folder_count_on_update");
+ db.execSQL("DROP TRIGGER IF EXISTS decrease_folder_count_on_update");
+ db.execSQL("DROP TRIGGER IF EXISTS decrease_folder_count_on_delete");
+ db.execSQL("DROP TRIGGER IF EXISTS delete_data_on_delete");
+ db.execSQL("DROP TRIGGER IF EXISTS increase_folder_count_on_insert");
+ db.execSQL("DROP TRIGGER IF EXISTS folder_delete_notes_on_delete");
+ db.execSQL("DROP TRIGGER IF EXISTS folder_move_notes_on_trash");
+
+ db.execSQL(NOTE_INCREASE_FOLDER_COUNT_ON_UPDATE_TRIGGER);
+ db.execSQL(NOTE_DECREASE_FOLDER_COUNT_ON_UPDATE_TRIGGER);
+ db.execSQL(NOTE_DECREASE_FOLDER_COUNT_ON_DELETE_TRIGGER);
+ db.execSQL(NOTE_DELETE_DATA_ON_DELETE_TRIGGER);
+ db.execSQL(NOTE_INCREASE_FOLDER_COUNT_ON_INSERT_TRIGGER);
+ db.execSQL(FOLDER_DELETE_NOTES_ON_DELETE_TRIGGER);
+ db.execSQL(FOLDER_MOVE_NOTES_ON_TRASH_TRIGGER);
+ }
+ public void dosearch(String querystring) //搜索时不区分大小写,仿照上面的递归
+ {
+ Cursor cursor = null;
+ SQLiteDatabase db = mInstance.getReadableDatabase();
+ String query_sql_string = "select * from " + TABLE.DATA + " where content like " + "'%"+ querystring + "%'";
+ //Log.i(TAG,query_sql_string);
+ cursor = db.rawQuery(query_sql_string,null);
+ cursor.moveToFirst();
+ if(cursor!=null)
+ {
+ while(cursor.moveToNext())
+ {
+
+ String content = cursor.getString(cursor.getColumnIndex("content"));
+ Log.i(TAG, cursor.getString(cursor.getColumnIndex("_id")));
+ }
+ }
+ cursor.close();
+ }
+ private void createSystemFolder(SQLiteDatabase db) {
+ ContentValues values = new ContentValues();
+
+ /**
+ * call record foler for call notes
+ */
+ values.put(NoteColumns.ID, Notes.ID_CALL_RECORD_FOLDER);
+ values.put(NoteColumns.TYPE, Notes.TYPE_SYSTEM);
+ db.insert(TABLE.NOTE, null, values);
+
+ /**
+ * root folder which is default folder
+ */
+ values.clear();
+ values.put(NoteColumns.ID, Notes.ID_ROOT_FOLDER);
+ values.put(NoteColumns.TYPE, Notes.TYPE_SYSTEM);
+ db.insert(TABLE.NOTE, null, values);
+
+ /**
+ * temporary folder which is used for moving note
+ */
+ values.clear();
+ values.put(NoteColumns.ID, Notes.ID_TEMPARAY_FOLDER);
+ values.put(NoteColumns.TYPE, Notes.TYPE_SYSTEM);
+ db.insert(TABLE.NOTE, null, values);
+
+ /**
+ * create trash folder
+ */
+ values.clear();
+ values.put(NoteColumns.ID, Notes.ID_TRASH_FOLER);
+ values.put(NoteColumns.TYPE, Notes.TYPE_SYSTEM);
+ db.insert(TABLE.NOTE, null, values);
+ }
+
+ public void createDataTable(SQLiteDatabase db) {
+ db.execSQL(CREATE_DATA_TABLE_SQL);
+ reCreateDataTableTriggers(db);
+ db.execSQL(CREATE_DATA_NOTE_ID_INDEX_SQL);
+ Log.d(TAG, "data table has been created");
+ }
+
+ private void reCreateDataTableTriggers(SQLiteDatabase db) {
+ db.execSQL("DROP TRIGGER IF EXISTS update_note_content_on_insert");
+ db.execSQL("DROP TRIGGER IF EXISTS update_note_content_on_update");
+ db.execSQL("DROP TRIGGER IF EXISTS update_note_content_on_delete");
+
+ db.execSQL(DATA_UPDATE_NOTE_CONTENT_ON_INSERT_TRIGGER);
+ db.execSQL(DATA_UPDATE_NOTE_CONTENT_ON_UPDATE_TRIGGER);
+ db.execSQL(DATA_UPDATE_NOTE_CONTENT_ON_DELETE_TRIGGER);
+ }
+
+ static synchronized NotesDatabaseHelper getInstance(Context context) {
+ if (mInstance == null) {
+ mInstance = new NotesDatabaseHelper(context);
+ }
+ return mInstance;
+ }
+
+ @Override
+ public void onCreate(SQLiteDatabase db) {
+ createNoteTable(db);
+ createDataTable(db);
+ }
+
+ @Override
+ public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) {
+ boolean reCreateTriggers = false;
+ boolean skipV2 = false;
+
+ if (oldVersion == 1) {
+ upgradeToV2(db);
+ skipV2 = true; // this upgrade including the upgrade from v2 to v3
+ oldVersion++;
+ }
+
+ if (oldVersion == 2 && !skipV2) {
+ upgradeToV3(db);
+ reCreateTriggers = true;
+ oldVersion++;
+ }
+
+ if (oldVersion == 3) {
+ upgradeToV4(db);
+ oldVersion++;
+ }
+
+ if (reCreateTriggers) {
+ reCreateNoteTableTriggers(db);
+ reCreateDataTableTriggers(db);
+ }
+
+ if (oldVersion != newVersion) {
+ throw new IllegalStateException("Upgrade notes database to version " + newVersion
+ + "fails");
+ }
+ }
+
+ private void upgradeToV2(SQLiteDatabase db) {
+ db.execSQL("DROP TABLE IF EXISTS " + TABLE.NOTE);
+ db.execSQL("DROP TABLE IF EXISTS " + TABLE.DATA);
+ createNoteTable(db);
+ createDataTable(db);
+ }
+
+ private void upgradeToV3(SQLiteDatabase db) {
+ // drop unused triggers
+ db.execSQL("DROP TRIGGER IF EXISTS update_note_modified_date_on_insert");
+ db.execSQL("DROP TRIGGER IF EXISTS update_note_modified_date_on_delete");
+ db.execSQL("DROP TRIGGER IF EXISTS update_note_modified_date_on_update");
+ // add a column for gtask id
+ db.execSQL("ALTER TABLE " + TABLE.NOTE + " ADD COLUMN " + NoteColumns.GTASK_ID
+ + " TEXT NOT NULL DEFAULT ''");
+ // add a trash system folder
+ ContentValues values = new ContentValues();
+ values.put(NoteColumns.ID, Notes.ID_TRASH_FOLER);
+ values.put(NoteColumns.TYPE, Notes.TYPE_SYSTEM);
+ db.insert(TABLE.NOTE, null, values);
+ }
+
+ private void upgradeToV4(SQLiteDatabase db) {
+ db.execSQL("ALTER TABLE " + TABLE.NOTE + " ADD COLUMN " + NoteColumns.VERSION
+ + " INTEGER NOT NULL DEFAULT 0");
+ }
+}
diff --git a/src/src/app/src/main/java/net/micode/notes/data/NotesProvider.java b/src/src/app/src/main/java/net/micode/notes/data/NotesProvider.java
new file mode 100644
index 0000000..edb0a60
--- /dev/null
+++ b/src/src/app/src/main/java/net/micode/notes/data/NotesProvider.java
@@ -0,0 +1,305 @@
+/*
+ * Copyright (c) 2010-2011, The MiCode Open Source Community (www.micode.net)
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+
+package net.micode.notes.data;
+
+
+import android.app.SearchManager;
+import android.content.ContentProvider;
+import android.content.ContentUris;
+import android.content.ContentValues;
+import android.content.Intent;
+import android.content.UriMatcher;
+import android.database.Cursor;
+import android.database.sqlite.SQLiteDatabase;
+import android.net.Uri;
+import android.text.TextUtils;
+import android.util.Log;
+
+import net.micode.notes.R;
+import net.micode.notes.data.Notes.DataColumns;
+import net.micode.notes.data.Notes.NoteColumns;
+import net.micode.notes.data.NotesDatabaseHelper.TABLE;
+
+
+public class NotesProvider extends ContentProvider {
+ private static final UriMatcher mMatcher;
+
+ private NotesDatabaseHelper mHelper;
+
+ private static final String TAG = "NotesProvider";
+
+ private static final int URI_NOTE = 1;
+ private static final int URI_NOTE_ITEM = 2;
+ private static final int URI_DATA = 3;
+ private static final int URI_DATA_ITEM = 4;
+
+ private static final int URI_SEARCH = 5;
+ private static final int URI_SEARCH_SUGGEST = 6;
+
+ static {
+ mMatcher = new UriMatcher(UriMatcher.NO_MATCH);
+ mMatcher.addURI(Notes.AUTHORITY, "note", URI_NOTE);
+ mMatcher.addURI(Notes.AUTHORITY, "note/#", URI_NOTE_ITEM);
+ mMatcher.addURI(Notes.AUTHORITY, "data", URI_DATA);
+ mMatcher.addURI(Notes.AUTHORITY, "data/#", URI_DATA_ITEM);
+ mMatcher.addURI(Notes.AUTHORITY, "search", URI_SEARCH);
+ mMatcher.addURI(Notes.AUTHORITY, SearchManager.SUGGEST_URI_PATH_QUERY, URI_SEARCH_SUGGEST);
+ mMatcher.addURI(Notes.AUTHORITY, SearchManager.SUGGEST_URI_PATH_QUERY + "/*", URI_SEARCH_SUGGEST);
+ }
+
+ /**
+ * x'0A' represents the '\n' character in sqlite. For title and content in the search result,
+ * we will trim '\n' and white space in order to show more information.
+ */
+ private static final String NOTES_SEARCH_PROJECTION = NoteColumns.ID + ","
+ + NoteColumns.ID + " AS " + SearchManager.SUGGEST_COLUMN_INTENT_EXTRA_DATA + ","
+ + "TRIM(REPLACE(" + NoteColumns.SNIPPET + ", x'0A','')) AS " + SearchManager.SUGGEST_COLUMN_TEXT_1 + ","
+ + "TRIM(REPLACE(" + NoteColumns.SNIPPET + ", x'0A','')) AS " + SearchManager.SUGGEST_COLUMN_TEXT_2 + ","
+ + R.drawable.search_result + " AS " + SearchManager.SUGGEST_COLUMN_ICON_1 + ","
+ + "'" + Intent.ACTION_VIEW + "' AS " + SearchManager.SUGGEST_COLUMN_INTENT_ACTION + ","
+ + "'" + Notes.TextNote.CONTENT_TYPE + "' AS " + SearchManager.SUGGEST_COLUMN_INTENT_DATA;
+
+ private static String NOTES_SNIPPET_SEARCH_QUERY = "SELECT " + NOTES_SEARCH_PROJECTION
+ + " FROM " + TABLE.NOTE
+ + " WHERE " + NoteColumns.SNIPPET + " LIKE ?"
+ + " AND " + NoteColumns.PARENT_ID + "<>" + Notes.ID_TRASH_FOLER
+ + " AND " + NoteColumns.TYPE + "=" + Notes.TYPE_NOTE;
+
+ @Override
+ public boolean onCreate() {
+ mHelper = NotesDatabaseHelper.getInstance(getContext());
+ return true;
+ }
+
+ @Override
+ public Cursor query(Uri uri, String[] projection, String selection, String[] selectionArgs,
+ String sortOrder) {
+ Cursor c = null;
+ SQLiteDatabase db = mHelper.getReadableDatabase();
+ String id = null;
+ switch (mMatcher.match(uri)) {
+ case URI_NOTE:
+ c = db.query(TABLE.NOTE, projection, selection, selectionArgs, null, null,
+ sortOrder);
+ break;
+ case URI_NOTE_ITEM:
+ id = uri.getPathSegments().get(1);
+ c = db.query(TABLE.NOTE, projection, NoteColumns.ID + "=" + id
+ + parseSelection(selection), selectionArgs, null, null, sortOrder);
+ break;
+ case URI_DATA:
+ c = db.query(TABLE.DATA, projection, selection, selectionArgs, null, null,
+ sortOrder);
+ break;
+ case URI_DATA_ITEM:
+ id = uri.getPathSegments().get(1);
+ c = db.query(TABLE.DATA, projection, DataColumns.ID + "=" + id
+ + parseSelection(selection), selectionArgs, null, null, sortOrder);
+ break;
+ case URI_SEARCH:
+ case URI_SEARCH_SUGGEST:
+ if (sortOrder != null || projection != null) {
+ throw new IllegalArgumentException(
+ "do not specify sortOrder, selection, selectionArgs, or projection" + "with this query");
+ }
+
+ String searchString = null;
+ if (mMatcher.match(uri) == URI_SEARCH_SUGGEST) {
+ if (uri.getPathSegments().size() > 1) {
+ searchString = uri.getPathSegments().get(1);
+ }
+ } else {
+ searchString = uri.getQueryParameter("pattern");
+ }
+
+ if (TextUtils.isEmpty(searchString)) {
+ return null;
+ }
+
+ try {
+ searchString = String.format("%%%s%%", searchString);
+ c = db.rawQuery(NOTES_SNIPPET_SEARCH_QUERY,
+ new String[] { searchString });
+ } catch (IllegalStateException ex) {
+ Log.e(TAG, "got exception: " + ex.toString());
+ }
+ break;
+ default:
+ throw new IllegalArgumentException("Unknown URI " + uri);
+ }
+ if (c != null) {
+ c.setNotificationUri(getContext().getContentResolver(), uri);
+ }
+ return c;
+ }
+
+ @Override
+ public Uri insert(Uri uri, ContentValues values) {
+ SQLiteDatabase db = mHelper.getWritableDatabase();
+ long dataId = 0, noteId = 0, insertedId = 0;
+ switch (mMatcher.match(uri)) {
+ case URI_NOTE:
+ insertedId = noteId = db.insert(TABLE.NOTE, null, values);
+ break;
+ case URI_DATA:
+ if (values.containsKey(DataColumns.NOTE_ID)) {
+ noteId = values.getAsLong(DataColumns.NOTE_ID);
+ } else {
+ Log.d(TAG, "Wrong data format without note id:" + values.toString());
+ }
+ insertedId = dataId = db.insert(TABLE.DATA, null, values);
+ break;
+ default:
+ throw new IllegalArgumentException("Unknown URI " + uri);
+ }
+ // Notify the note uri
+ if (noteId > 0) {
+ getContext().getContentResolver().notifyChange(
+ ContentUris.withAppendedId(Notes.CONTENT_NOTE_URI, noteId), null);
+ }
+
+ // Notify the data uri
+ if (dataId > 0) {
+ getContext().getContentResolver().notifyChange(
+ ContentUris.withAppendedId(Notes.CONTENT_DATA_URI, dataId), null);
+ }
+
+ return ContentUris.withAppendedId(uri, insertedId);
+ }
+
+ @Override
+ public int delete(Uri uri, String selection, String[] selectionArgs) {
+ int count = 0;
+ String id = null;
+ SQLiteDatabase db = mHelper.getWritableDatabase();
+ boolean deleteData = false;
+ switch (mMatcher.match(uri)) {
+ case URI_NOTE:
+ selection = "(" + selection + ") AND " + NoteColumns.ID + ">0 ";
+ count = db.delete(TABLE.NOTE, selection, selectionArgs);
+ break;
+ case URI_NOTE_ITEM:
+ id = uri.getPathSegments().get(1);
+ /**
+ * ID that smaller than 0 is system folder which is not allowed to
+ * trash
+ */
+ long noteId = Long.valueOf(id);
+ if (noteId <= 0) {
+ break;
+ }
+ count = db.delete(TABLE.NOTE,
+ NoteColumns.ID + "=" + id + parseSelection(selection), selectionArgs);
+ break;
+ case URI_DATA:
+ count = db.delete(TABLE.DATA, selection, selectionArgs);
+ deleteData = true;
+ break;
+ case URI_DATA_ITEM:
+ id = uri.getPathSegments().get(1);
+ count = db.delete(TABLE.DATA,
+ DataColumns.ID + "=" + id + parseSelection(selection), selectionArgs);
+ deleteData = true;
+ break;
+ default:
+ throw new IllegalArgumentException("Unknown URI " + uri);
+ }
+ if (count > 0) {
+ if (deleteData) {
+ getContext().getContentResolver().notifyChange(Notes.CONTENT_NOTE_URI, null);
+ }
+ getContext().getContentResolver().notifyChange(uri, null);
+ }
+ return count;
+ }
+
+ @Override
+ public int update(Uri uri, ContentValues values, String selection, String[] selectionArgs) {
+ int count = 0;
+ String id = null;
+ SQLiteDatabase db = mHelper.getWritableDatabase();
+ boolean updateData = false;
+ switch (mMatcher.match(uri)) {
+ case URI_NOTE:
+ increaseNoteVersion(-1, selection, selectionArgs);
+ count = db.update(TABLE.NOTE, values, selection, selectionArgs);
+ break;
+ case URI_NOTE_ITEM:
+ id = uri.getPathSegments().get(1);
+ increaseNoteVersion(Long.valueOf(id), selection, selectionArgs);
+ count = db.update(TABLE.NOTE, values, NoteColumns.ID + "=" + id
+ + parseSelection(selection), selectionArgs);
+ break;
+ case URI_DATA:
+ count = db.update(TABLE.DATA, values, selection, selectionArgs);
+ updateData = true;
+ break;
+ case URI_DATA_ITEM:
+ id = uri.getPathSegments().get(1);
+ count = db.update(TABLE.DATA, values, DataColumns.ID + "=" + id
+ + parseSelection(selection), selectionArgs);
+ updateData = true;
+ break;
+ default:
+ throw new IllegalArgumentException("Unknown URI " + uri);
+ }
+
+ if (count > 0) {
+ if (updateData) {
+ getContext().getContentResolver().notifyChange(Notes.CONTENT_NOTE_URI, null);
+ }
+ getContext().getContentResolver().notifyChange(uri, null);
+ }
+ return count;
+ }
+
+ private String parseSelection(String selection) {
+ return (!TextUtils.isEmpty(selection) ? " AND (" + selection + ')' : "");
+ }
+
+ private void increaseNoteVersion(long id, String selection, String[] selectionArgs) {
+ StringBuilder sql = new StringBuilder(120);
+ sql.append("UPDATE ");
+ sql.append(TABLE.NOTE);
+ sql.append(" SET ");
+ sql.append(NoteColumns.VERSION);
+ sql.append("=" + NoteColumns.VERSION + "+1 ");
+
+ if (id > 0 || !TextUtils.isEmpty(selection)) {
+ sql.append(" WHERE ");
+ }
+ if (id > 0) {
+ sql.append(NoteColumns.ID + "=" + String.valueOf(id));
+ }
+ if (!TextUtils.isEmpty(selection)) {
+ String selectString = id > 0 ? parseSelection(selection) : selection;
+ for (String args : selectionArgs) {
+ selectString = selectString.replaceFirst("\\?", args);
+ }
+ sql.append(selectString);
+ }
+
+ mHelper.getWritableDatabase().execSQL(sql.toString());
+ }
+
+ @Override
+ public String getType(Uri uri) {
+ // TODO Auto-generated method stub
+ return null;
+ }
+
+}
diff --git a/src/src/app/src/main/java/net/micode/notes/gtask/data/MetaData.java b/src/src/app/src/main/java/net/micode/notes/gtask/data/MetaData.java
new file mode 100644
index 0000000..3a2050b
--- /dev/null
+++ b/src/src/app/src/main/java/net/micode/notes/gtask/data/MetaData.java
@@ -0,0 +1,82 @@
+/*
+ * Copyright (c) 2010-2011, The MiCode Open Source Community (www.micode.net)
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+
+package net.micode.notes.gtask.data;
+
+import android.database.Cursor;
+import android.util.Log;
+
+import net.micode.notes.tool.GTaskStringUtils;
+
+import org.json.JSONException;
+import org.json.JSONObject;
+
+
+public class MetaData extends Task {
+ private final static String TAG = MetaData.class.getSimpleName();
+
+ private String mRelatedGid = null;
+
+ public void setMeta(String gid, JSONObject metaInfo) {
+ try {
+ metaInfo.put(GTaskStringUtils.META_HEAD_GTASK_ID, gid);
+ } catch (JSONException e) {
+ Log.e(TAG, "failed to put related gid");
+ }
+ setNotes(metaInfo.toString());
+ setName(GTaskStringUtils.META_NOTE_NAME);
+ }
+
+ public String getRelatedGid() {
+ return mRelatedGid;
+ }
+
+ @Override
+ public boolean isWorthSaving() {
+ return getNotes() != null;
+ }
+
+ @Override
+ public void setContentByRemoteJSON(JSONObject js) {
+ super.setContentByRemoteJSON(js);
+ if (getNotes() != null) {
+ try {
+ JSONObject metaInfo = new JSONObject(getNotes().trim());
+ mRelatedGid = metaInfo.getString(GTaskStringUtils.META_HEAD_GTASK_ID);
+ } catch (JSONException e) {
+ Log.w(TAG, "failed to get related gid");
+ mRelatedGid = null;
+ }
+ }
+ }
+
+ @Override
+ public void setContentByLocalJSON(JSONObject js) {
+ // this function should not be called
+ throw new IllegalAccessError("MetaData:setContentByLocalJSON should not be called");
+ }
+
+ @Override
+ public JSONObject getLocalJSONFromContent() {
+ throw new IllegalAccessError("MetaData:getLocalJSONFromContent should not be called");
+ }
+
+ @Override
+ public int getSyncAction(Cursor c) {
+ throw new IllegalAccessError("MetaData:getSyncAction should not be called");
+ }
+
+}
diff --git a/src/src/app/src/main/java/net/micode/notes/gtask/data/Node.java b/src/src/app/src/main/java/net/micode/notes/gtask/data/Node.java
new file mode 100644
index 0000000..63950e0
--- /dev/null
+++ b/src/src/app/src/main/java/net/micode/notes/gtask/data/Node.java
@@ -0,0 +1,101 @@
+/*
+ * Copyright (c) 2010-2011, The MiCode Open Source Community (www.micode.net)
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+
+package net.micode.notes.gtask.data;
+
+import android.database.Cursor;
+
+import org.json.JSONObject;
+
+public abstract class Node {
+ public static final int SYNC_ACTION_NONE = 0;
+
+ public static final int SYNC_ACTION_ADD_REMOTE = 1;
+
+ public static final int SYNC_ACTION_ADD_LOCAL = 2;
+
+ public static final int SYNC_ACTION_DEL_REMOTE = 3;
+
+ public static final int SYNC_ACTION_DEL_LOCAL = 4;
+
+ public static final int SYNC_ACTION_UPDATE_REMOTE = 5;
+
+ public static final int SYNC_ACTION_UPDATE_LOCAL = 6;
+
+ public static final int SYNC_ACTION_UPDATE_CONFLICT = 7;
+
+ public static final int SYNC_ACTION_ERROR = 8;
+
+ private String mGid;
+
+ private String mName;
+
+ private long mLastModified;
+
+ private boolean mDeleted;
+
+ public Node() {
+ mGid = null;
+ mName = "";
+ mLastModified = 0;
+ mDeleted = false;
+ }
+
+ public abstract JSONObject getCreateAction(int actionId);
+
+ public abstract JSONObject getUpdateAction(int actionId);
+
+ public abstract void setContentByRemoteJSON(JSONObject js);
+
+ public abstract void setContentByLocalJSON(JSONObject js);
+
+ public abstract JSONObject getLocalJSONFromContent();
+
+ public abstract int getSyncAction(Cursor c);
+
+ public void setGid(String gid) {
+ this.mGid = gid;
+ }
+
+ public void setName(String name) {
+ this.mName = name;
+ }
+
+ public void setLastModified(long lastModified) {
+ this.mLastModified = lastModified;
+ }
+
+ public void setDeleted(boolean deleted) {
+ this.mDeleted = deleted;
+ }
+
+ public String getGid() {
+ return this.mGid;
+ }
+
+ public String getName() {
+ return this.mName;
+ }
+
+ public long getLastModified() {
+ return this.mLastModified;
+ }
+
+ public boolean getDeleted() {
+ return this.mDeleted;
+ }
+
+}
diff --git a/src/src/app/src/main/java/net/micode/notes/gtask/data/SqlData.java b/src/src/app/src/main/java/net/micode/notes/gtask/data/SqlData.java
new file mode 100644
index 0000000..cb0aabb
--- /dev/null
+++ b/src/src/app/src/main/java/net/micode/notes/gtask/data/SqlData.java
@@ -0,0 +1,194 @@
+/*
+ * Copyright (c) 2010-2011, The MiCode Open Source Community (www.micode.net)
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+
+package net.micode.notes.gtask.data;
+
+import android.content.ContentResolver;
+import android.content.ContentUris;
+import android.content.ContentValues;
+import android.content.Context;
+import android.database.Cursor;
+import android.net.Uri;
+import android.util.Log;
+
+import net.micode.notes.data.Notes;
+import net.micode.notes.data.Notes.DataColumns;
+import net.micode.notes.data.Notes.DataConstants;
+import net.micode.notes.data.Notes.NoteColumns;
+import net.micode.notes.data.NotesDatabaseHelper.TABLE;
+import net.micode.notes.gtask.exception.ActionFailureException;
+
+import org.json.JSONException;
+import org.json.JSONObject;
+
+
+public class SqlData {
+ private static final String TAG = SqlData.class.getSimpleName();
+
+ private static final int INVALID_ID = -99999;
+
+ public static final String[] PROJECTION_DATA = new String[] {
+ DataColumns.ID, DataColumns.MIME_TYPE, DataColumns.CONTENT, DataColumns.DATA1,
+ DataColumns.DATA3
+ };
+
+ public static final int DATA_ID_COLUMN = 0;
+
+ public static final int DATA_MIME_TYPE_COLUMN = 1;
+
+ public static final int DATA_CONTENT_COLUMN = 2;
+
+ public static final int DATA_CONTENT_DATA_1_COLUMN = 3;
+
+ public static final int DATA_CONTENT_DATA_3_COLUMN = 4;
+
+ private ContentResolver mContentResolver;
+
+ private boolean mIsCreate;
+
+ private long mDataId;
+
+ private String mDataMimeType;
+
+ private String mDataContent;
+
+ private long mDataContentData1;
+
+ private String mDataContentData3;
+
+ private ContentValues mDiffDataValues;
+
+ public SqlData(Context context) {
+ mContentResolver = context.getContentResolver();
+ mIsCreate = true;
+ mDataId = INVALID_ID;
+ mDataMimeType = DataConstants.NOTE;
+ mDataContent = "";
+ mDataContentData1 = 0;
+ mDataContentData3 = "";
+ mDiffDataValues = new ContentValues();
+ }
+
+ public SqlData(Context context, Cursor c) {
+ mContentResolver = context.getContentResolver();
+ mIsCreate = false;
+ loadFromCursor(c);
+ mDiffDataValues = new ContentValues();
+ }
+
+ private void loadFromCursor(Cursor c) {
+ mDataId = c.getLong(DATA_ID_COLUMN);
+ mDataMimeType = c.getString(DATA_MIME_TYPE_COLUMN);
+ mDataContent = c.getString(DATA_CONTENT_COLUMN);
+ mDataContentData1 = c.getLong(DATA_CONTENT_DATA_1_COLUMN);
+ mDataContentData3 = c.getString(DATA_CONTENT_DATA_3_COLUMN);
+ }
+
+ public void setContent(JSONObject js) throws JSONException {
+ long dataId = js.has(DataColumns.ID) ? js.getLong(DataColumns.ID) : INVALID_ID;
+ if (mIsCreate || mDataId != dataId) {
+ mDiffDataValues.put(DataColumns.ID, dataId);
+ }
+ mDataId = dataId;
+
+ String dataMimeType = js.has(DataColumns.MIME_TYPE) ? js.getString(DataColumns.MIME_TYPE)
+ : DataConstants.NOTE;
+ if (mIsCreate || !mDataMimeType.equals(dataMimeType)) {
+ mDiffDataValues.put(DataColumns.MIME_TYPE, dataMimeType);
+ }
+ mDataMimeType = dataMimeType;
+
+ String dataContent = js.has(DataColumns.CONTENT) ? js.getString(DataColumns.CONTENT) : "";
+ if (mIsCreate || !mDataContent.equals(dataContent)) {
+ mDiffDataValues.put(DataColumns.CONTENT, dataContent);
+ }
+ mDataContent = dataContent;
+
+ long dataContentData1 = js.has(DataColumns.DATA1) ? js.getLong(DataColumns.DATA1) : 0;
+ if (mIsCreate || mDataContentData1 != dataContentData1) {
+ mDiffDataValues.put(DataColumns.DATA1, dataContentData1);
+ }
+ mDataContentData1 = dataContentData1;
+
+ String dataContentData3 = js.has(DataColumns.DATA3) ? js.getString(DataColumns.DATA3) : "";
+ if (mIsCreate || !mDataContentData3.equals(dataContentData3)) {
+ mDiffDataValues.put(DataColumns.DATA3, dataContentData3);
+ }
+ mDataContentData3 = dataContentData3;
+ }
+
+ public JSONObject getContent() throws JSONException {
+ if (mIsCreate) {
+ Log.e(TAG, "it seems that we haven't created this in database yet");
+ return null;
+ }
+ JSONObject js = new JSONObject();
+ js.put(DataColumns.ID, mDataId);
+ js.put(DataColumns.MIME_TYPE, mDataMimeType);
+ js.put(DataColumns.CONTENT, mDataContent);
+ js.put(DataColumns.DATA1, mDataContentData1);
+ js.put(DataColumns.DATA3, mDataContentData3);
+ return js;
+ }
+ public void For_Commit_mIsCreate(long noteId, boolean validateVersion, long version){
+ if (mDataId == INVALID_ID && mDiffDataValues.containsKey(DataColumns.ID)) {
+ mDiffDataValues.remove(DataColumns.ID);
+ }
+
+ mDiffDataValues.put(DataColumns.NOTE_ID, noteId);
+ Uri uri = mContentResolver.insert(Notes.CONTENT_DATA_URI, mDiffDataValues);
+ try {
+ mDataId = Long.valueOf(uri.getPathSegments().get(1));
+ } catch (NumberFormatException e) {
+ Log.e(TAG, "Get note id error :" + e.toString());
+ throw new ActionFailureException("create note failed");
+ }
+ }
+ public void For_Commit_Not_mIsCreate(long noteId, boolean validateVersion, long version){
+ if (mDiffDataValues.size() > 0) {
+ int result = 0;
+ if (!validateVersion) {
+ result = mContentResolver.update(ContentUris.withAppendedId(
+ Notes.CONTENT_DATA_URI, mDataId), mDiffDataValues, null, null);
+ } else {
+ result = mContentResolver.update(ContentUris.withAppendedId(
+ Notes.CONTENT_DATA_URI, mDataId), mDiffDataValues,
+ " ? in (SELECT " + NoteColumns.ID + " FROM " + TABLE.NOTE
+ + " WHERE " + NoteColumns.VERSION + "=?)", new String[] {
+ String.valueOf(noteId), String.valueOf(version)
+ });
+ }
+ if (result == 0) {
+ Log.w(TAG, "there is no update. maybe user updates note when syncing");
+ }
+ }
+ }
+ public void commit(long noteId, boolean validateVersion, long version) {
+
+ if (mIsCreate) {
+ For_Commit_mIsCreate(noteId, validateVersion, version);
+ } else {
+ For_Commit_Not_mIsCreate(noteId, validateVersion,version);
+ }
+
+ mDiffDataValues.clear();
+ mIsCreate = false;
+ }
+
+ public long getId() {
+ return mDataId;
+ }
+}
diff --git a/src/src/app/src/main/java/net/micode/notes/gtask/data/SqlNote.java b/src/src/app/src/main/java/net/micode/notes/gtask/data/SqlNote.java
new file mode 100644
index 0000000..c945838
--- /dev/null
+++ b/src/src/app/src/main/java/net/micode/notes/gtask/data/SqlNote.java
@@ -0,0 +1,505 @@
+/*
+ * Copyright (c) 2010-2011, The MiCode Open Source Community (www.micode.net)
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+
+package net.micode.notes.gtask.data;
+
+import android.appwidget.AppWidgetManager;
+import android.content.ContentResolver;
+import android.content.ContentValues;
+import android.content.Context;
+import android.database.Cursor;
+import android.net.Uri;
+import android.util.Log;
+
+import net.micode.notes.data.Notes;
+import net.micode.notes.data.Notes.DataColumns;
+import net.micode.notes.data.Notes.NoteColumns;
+import net.micode.notes.gtask.exception.ActionFailureException;
+import net.micode.notes.tool.GTaskStringUtils;
+import net.micode.notes.tool.ResourceParser;
+
+import org.json.JSONArray;
+import org.json.JSONException;
+import org.json.JSONObject;
+
+import java.util.ArrayList;
+
+
+public class SqlNote {
+ private static final String TAG = SqlNote.class.getSimpleName();
+
+ private static final int INVALID_ID = -99999;
+
+ public static final String[] PROJECTION_NOTE = new String[] {
+ NoteColumns.ID, NoteColumns.ALERTED_DATE, NoteColumns.BG_COLOR_ID,
+ NoteColumns.CREATED_DATE, NoteColumns.HAS_ATTACHMENT, NoteColumns.MODIFIED_DATE,
+ NoteColumns.NOTES_COUNT, NoteColumns.PARENT_ID, NoteColumns.SNIPPET, NoteColumns.TYPE,
+ NoteColumns.WIDGET_ID, NoteColumns.WIDGET_TYPE, NoteColumns.SYNC_ID,
+ NoteColumns.LOCAL_MODIFIED, NoteColumns.ORIGIN_PARENT_ID, NoteColumns.GTASK_ID,
+ NoteColumns.VERSION
+ };
+
+ public static final int ID_COLUMN = 0;
+
+ public static final int ALERTED_DATE_COLUMN = 1;
+
+ public static final int BG_COLOR_ID_COLUMN = 2;
+
+ public static final int CREATED_DATE_COLUMN = 3;
+
+ public static final int HAS_ATTACHMENT_COLUMN = 4;
+
+ public static final int MODIFIED_DATE_COLUMN = 5;
+
+ public static final int NOTES_COUNT_COLUMN = 6;
+
+ public static final int PARENT_ID_COLUMN = 7;
+
+ public static final int SNIPPET_COLUMN = 8;
+
+ public static final int TYPE_COLUMN = 9;
+
+ public static final int WIDGET_ID_COLUMN = 10;
+
+ public static final int WIDGET_TYPE_COLUMN = 11;
+
+ public static final int SYNC_ID_COLUMN = 12;
+
+ public static final int LOCAL_MODIFIED_COLUMN = 13;
+
+ public static final int ORIGIN_PARENT_ID_COLUMN = 14;
+
+ public static final int GTASK_ID_COLUMN = 15;
+
+ public static final int VERSION_COLUMN = 16;
+
+ private Context mContext;
+
+ private ContentResolver mContentResolver;
+
+ private boolean mIsCreate;
+
+ private long mId;
+
+ private long mAlertDate;
+
+ private int mBgColorId;
+
+ private long mCreatedDate;
+
+ private int mHasAttachment;
+
+ private long mModifiedDate;
+
+ private long mParentId;
+
+ private String mSnippet;
+
+ private int mType;
+
+ private int mWidgetId;
+
+ private int mWidgetType;
+
+ private long mOriginParent;
+
+ private long mVersion;
+
+ private ContentValues mDiffNoteValues;
+
+ private ArrayList mDataList;
+
+ public SqlNote(Context context) {
+ mContext = context;
+ mContentResolver = context.getContentResolver();
+ mIsCreate = true;
+ mId = INVALID_ID;
+ mAlertDate = 0;
+ mBgColorId = ResourceParser.getDefaultBgId(context);
+ mCreatedDate = System.currentTimeMillis();
+ mHasAttachment = 0;
+ mModifiedDate = System.currentTimeMillis();
+ mParentId = 0;
+ mSnippet = "";
+ mType = Notes.TYPE_NOTE;
+ mWidgetId = AppWidgetManager.INVALID_APPWIDGET_ID;
+ mWidgetType = Notes.TYPE_WIDGET_INVALIDE;
+ mOriginParent = 0;
+ mVersion = 0;
+ mDiffNoteValues = new ContentValues();
+ mDataList = new ArrayList();
+ }
+
+ public SqlNote(Context context, Cursor c) {
+ mContext = context;
+ mContentResolver = context.getContentResolver();
+ mIsCreate = false;
+ loadFromCursor(c);
+ mDataList = new ArrayList();
+ if (mType == Notes.TYPE_NOTE)
+ loadDataContent();
+ mDiffNoteValues = new ContentValues();
+ }
+
+ public SqlNote(Context context, long id) {
+ mContext = context;
+ mContentResolver = context.getContentResolver();
+ mIsCreate = false;
+ loadFromCursor(id);
+ mDataList = new ArrayList();
+ if (mType == Notes.TYPE_NOTE)
+ loadDataContent();
+ mDiffNoteValues = new ContentValues();
+
+ }
+
+ private void loadFromCursor(long id) {
+ Cursor c = null;
+ try {
+ c = mContentResolver.query(Notes.CONTENT_NOTE_URI, PROJECTION_NOTE, "(_id=?)",
+ new String[] {
+ String.valueOf(id)
+ }, null);
+ if (c != null) {
+ c.moveToNext();
+ loadFromCursor(c);
+ } else {
+ Log.w(TAG, "loadFromCursor: cursor = null");
+ }
+ } finally {
+ if (c != null)
+ c.close();
+ }
+ }
+
+ private void loadFromCursor(Cursor c) {
+ mId = c.getLong(ID_COLUMN);
+ mAlertDate = c.getLong(ALERTED_DATE_COLUMN);
+ mBgColorId = c.getInt(BG_COLOR_ID_COLUMN);
+ mCreatedDate = c.getLong(CREATED_DATE_COLUMN);
+ mHasAttachment = c.getInt(HAS_ATTACHMENT_COLUMN);
+ mModifiedDate = c.getLong(MODIFIED_DATE_COLUMN);
+ mParentId = c.getLong(PARENT_ID_COLUMN);
+ mSnippet = c.getString(SNIPPET_COLUMN);
+ mType = c.getInt(TYPE_COLUMN);
+ mWidgetId = c.getInt(WIDGET_ID_COLUMN);
+ mWidgetType = c.getInt(WIDGET_TYPE_COLUMN);
+ mVersion = c.getLong(VERSION_COLUMN);
+ }
+
+ private void loadDataContent() {
+ Cursor c = null;
+ mDataList.clear();
+ try {
+ c = mContentResolver.query(Notes.CONTENT_DATA_URI, SqlData.PROJECTION_DATA,
+ "(note_id=?)", new String[] {
+ String.valueOf(mId)
+ }, null);
+ if (c != null) {
+ if (c.getCount() == 0) {
+ Log.w(TAG, "it seems that the note has not data");
+ return;
+ }
+ while (c.moveToNext()) {
+ SqlData data = new SqlData(mContext, c);
+ mDataList.add(data);
+ }
+ } else {
+ Log.w(TAG, "loadDataContent: cursor = null");
+ }
+ } finally {
+ if (c != null)
+ c.close();
+ }
+ }
+
+ public boolean setContent(JSONObject js) {
+ try {
+ JSONObject note = js.getJSONObject(GTaskStringUtils.META_HEAD_NOTE);
+ if (note.getInt(NoteColumns.TYPE) == Notes.TYPE_SYSTEM) {
+ Log.w(TAG, "cannot set system folder");
+ } else if (note.getInt(NoteColumns.TYPE) == Notes.TYPE_FOLDER) {
+ // for folder we can only update the snnipet and type
+ String snippet = note.has(NoteColumns.SNIPPET) ? note
+ .getString(NoteColumns.SNIPPET) : "";
+ if (mIsCreate || !mSnippet.equals(snippet)) {
+ mDiffNoteValues.put(NoteColumns.SNIPPET, snippet);
+ }
+ mSnippet = snippet;
+
+ int type = note.has(NoteColumns.TYPE) ? note.getInt(NoteColumns.TYPE)
+ : Notes.TYPE_NOTE;
+ if (mIsCreate || mType != type) {
+ mDiffNoteValues.put(NoteColumns.TYPE, type);
+ }
+ mType = type;
+ } else if (note.getInt(NoteColumns.TYPE) == Notes.TYPE_NOTE) {
+ JSONArray dataArray = js.getJSONArray(GTaskStringUtils.META_HEAD_DATA);
+ long id = note.has(NoteColumns.ID) ? note.getLong(NoteColumns.ID) : INVALID_ID;
+ if (mIsCreate || mId != id) {
+ mDiffNoteValues.put(NoteColumns.ID, id);
+ }
+ mId = id;
+
+ long alertDate = note.has(NoteColumns.ALERTED_DATE) ? note
+ .getLong(NoteColumns.ALERTED_DATE) : 0;
+ if (mIsCreate || mAlertDate != alertDate) {
+ mDiffNoteValues.put(NoteColumns.ALERTED_DATE, alertDate);
+ }
+ mAlertDate = alertDate;
+
+ int bgColorId = note.has(NoteColumns.BG_COLOR_ID) ? note
+ .getInt(NoteColumns.BG_COLOR_ID) : ResourceParser.getDefaultBgId(mContext);
+ if (mIsCreate || mBgColorId != bgColorId) {
+ mDiffNoteValues.put(NoteColumns.BG_COLOR_ID, bgColorId);
+ }
+ mBgColorId = bgColorId;
+
+ long createDate = note.has(NoteColumns.CREATED_DATE) ? note
+ .getLong(NoteColumns.CREATED_DATE) : System.currentTimeMillis();
+ if (mIsCreate || mCreatedDate != createDate) {
+ mDiffNoteValues.put(NoteColumns.CREATED_DATE, createDate);
+ }
+ mCreatedDate = createDate;
+
+ int hasAttachment = note.has(NoteColumns.HAS_ATTACHMENT) ? note
+ .getInt(NoteColumns.HAS_ATTACHMENT) : 0;
+ if (mIsCreate || mHasAttachment != hasAttachment) {
+ mDiffNoteValues.put(NoteColumns.HAS_ATTACHMENT, hasAttachment);
+ }
+ mHasAttachment = hasAttachment;
+
+ long modifiedDate = note.has(NoteColumns.MODIFIED_DATE) ? note
+ .getLong(NoteColumns.MODIFIED_DATE) : System.currentTimeMillis();
+ if (mIsCreate || mModifiedDate != modifiedDate) {
+ mDiffNoteValues.put(NoteColumns.MODIFIED_DATE, modifiedDate);
+ }
+ mModifiedDate = modifiedDate;
+
+ long parentId = note.has(NoteColumns.PARENT_ID) ? note
+ .getLong(NoteColumns.PARENT_ID) : 0;
+ if (mIsCreate || mParentId != parentId) {
+ mDiffNoteValues.put(NoteColumns.PARENT_ID, parentId);
+ }
+ mParentId = parentId;
+
+ String snippet = note.has(NoteColumns.SNIPPET) ? note
+ .getString(NoteColumns.SNIPPET) : "";
+ if (mIsCreate || !mSnippet.equals(snippet)) {
+ mDiffNoteValues.put(NoteColumns.SNIPPET, snippet);
+ }
+ mSnippet = snippet;
+
+ int type = note.has(NoteColumns.TYPE) ? note.getInt(NoteColumns.TYPE)
+ : Notes.TYPE_NOTE;
+ if (mIsCreate || mType != type) {
+ mDiffNoteValues.put(NoteColumns.TYPE, type);
+ }
+ mType = type;
+
+ int widgetId = note.has(NoteColumns.WIDGET_ID) ? note.getInt(NoteColumns.WIDGET_ID)
+ : AppWidgetManager.INVALID_APPWIDGET_ID;
+ if (mIsCreate || mWidgetId != widgetId) {
+ mDiffNoteValues.put(NoteColumns.WIDGET_ID, widgetId);
+ }
+ mWidgetId = widgetId;
+
+ int widgetType = note.has(NoteColumns.WIDGET_TYPE) ? note
+ .getInt(NoteColumns.WIDGET_TYPE) : Notes.TYPE_WIDGET_INVALIDE;
+ if (mIsCreate || mWidgetType != widgetType) {
+ mDiffNoteValues.put(NoteColumns.WIDGET_TYPE, widgetType);
+ }
+ mWidgetType = widgetType;
+
+ long originParent = note.has(NoteColumns.ORIGIN_PARENT_ID) ? note
+ .getLong(NoteColumns.ORIGIN_PARENT_ID) : 0;
+ if (mIsCreate || mOriginParent != originParent) {
+ mDiffNoteValues.put(NoteColumns.ORIGIN_PARENT_ID, originParent);
+ }
+ mOriginParent = originParent;
+
+ for (int i = 0; i < dataArray.length(); i++) {
+ JSONObject data = dataArray.getJSONObject(i);
+ SqlData sqlData = null;
+ if (data.has(DataColumns.ID)) {
+ long dataId = data.getLong(DataColumns.ID);
+ for (SqlData temp : mDataList) {
+ if (dataId == temp.getId()) {
+ sqlData = temp;
+ }
+ }
+ }
+
+ if (sqlData == null) {
+ sqlData = new SqlData(mContext);
+ mDataList.add(sqlData);
+ }
+
+ sqlData.setContent(data);
+ }
+ }
+ } catch (JSONException e) {
+ Log.e(TAG, e.toString());
+ //e.printStackTrace();
+ return false;
+ }
+ return true;
+ }
+
+ public JSONObject getContent() {
+ try {
+ JSONObject js = new JSONObject();
+
+ if (mIsCreate) {
+ Log.e(TAG, "it seems that we haven't created this in database yet");
+ return null;
+ }
+
+ JSONObject note = new JSONObject();
+ if (mType == Notes.TYPE_NOTE) {
+ note.put(NoteColumns.ID, mId);
+ note.put(NoteColumns.ALERTED_DATE, mAlertDate);
+ note.put(NoteColumns.BG_COLOR_ID, mBgColorId);
+ note.put(NoteColumns.CREATED_DATE, mCreatedDate);
+ note.put(NoteColumns.HAS_ATTACHMENT, mHasAttachment);
+ note.put(NoteColumns.MODIFIED_DATE, mModifiedDate);
+ note.put(NoteColumns.PARENT_ID, mParentId);
+ note.put(NoteColumns.SNIPPET, mSnippet);
+ note.put(NoteColumns.TYPE, mType);
+ note.put(NoteColumns.WIDGET_ID, mWidgetId);
+ note.put(NoteColumns.WIDGET_TYPE, mWidgetType);
+ note.put(NoteColumns.ORIGIN_PARENT_ID, mOriginParent);
+ js.put(GTaskStringUtils.META_HEAD_NOTE, note);
+
+ JSONArray dataArray = new JSONArray();
+ for (SqlData sqlData : mDataList) {
+ JSONObject data = sqlData.getContent();
+ if (data != null) {
+ dataArray.put(data);
+ }
+ }
+ js.put(GTaskStringUtils.META_HEAD_DATA, dataArray);
+ } else if (mType == Notes.TYPE_FOLDER || mType == Notes.TYPE_SYSTEM) {
+ note.put(NoteColumns.ID, mId);
+ note.put(NoteColumns.TYPE, mType);
+ note.put(NoteColumns.SNIPPET, mSnippet);
+ js.put(GTaskStringUtils.META_HEAD_NOTE, note);
+ }
+
+ return js;
+ } catch (JSONException e) {
+ Log.e(TAG, e.toString());
+ // e.printStackTrace();
+ }
+ return null;
+ }
+
+ public void setParentId(long id) {
+ mParentId = id;
+ mDiffNoteValues.put(NoteColumns.PARENT_ID, id);
+ }
+
+ public void setGtaskId(String gid) {
+ mDiffNoteValues.put(NoteColumns.GTASK_ID, gid);
+ }
+
+ public void setSyncId(long syncId) {
+ mDiffNoteValues.put(NoteColumns.SYNC_ID, syncId);
+ }
+
+ public void resetLocalModified() {
+ mDiffNoteValues.put(NoteColumns.LOCAL_MODIFIED, 0);
+ }
+
+ public long getId() {
+ return mId;
+ }
+
+ public long getParentId() {
+ return mParentId;
+ }
+
+ public String getSnippet() {
+ return mSnippet;
+ }
+
+ public boolean isNoteType() {
+ return mType == Notes.TYPE_NOTE;
+ }
+
+ public void commit(boolean validateVersion) {
+ if (mIsCreate) {
+ if (mId == INVALID_ID && mDiffNoteValues.containsKey(NoteColumns.ID)) {
+ mDiffNoteValues.remove(NoteColumns.ID);
+ }
+
+ Uri uri = mContentResolver.insert(Notes.CONTENT_NOTE_URI, mDiffNoteValues);
+ try {
+ mId = Long.valueOf(uri.getPathSegments().get(1));
+ } catch (NumberFormatException e) {
+ Log.e(TAG, "Get note id error :" + e.toString());
+ throw new ActionFailureException("create note failed");
+ }
+ if (mId == 0) {
+ throw new IllegalStateException("Create thread id failed");
+ }
+
+ if (mType == Notes.TYPE_NOTE) {
+ for (SqlData sqlData : mDataList) {
+ sqlData.commit(mId, false, -1);
+ }
+ }
+ } else {
+ if (mId <= 0 && mId != Notes.ID_ROOT_FOLDER && mId != Notes.ID_CALL_RECORD_FOLDER) {
+ Log.e(TAG, "No such note");
+ throw new IllegalStateException("Try to update note with invalid id");
+ }
+ if (mDiffNoteValues.size() > 0) {
+ mVersion ++;
+ int result = 0;
+ if (!validateVersion) {
+ result = mContentResolver.update(Notes.CONTENT_NOTE_URI, mDiffNoteValues, "("
+ + NoteColumns.ID + "=?)", new String[] {
+ String.valueOf(mId)
+ });
+ } else {
+ result = mContentResolver.update(Notes.CONTENT_NOTE_URI, mDiffNoteValues, "("
+ + NoteColumns.ID + "=?) AND (" + NoteColumns.VERSION + "<=?)",
+ new String[] {
+ String.valueOf(mId), String.valueOf(mVersion)
+ });
+ }
+ if (result == 0) {
+ Log.w(TAG, "there is no update. maybe user updates note when syncing");
+ }
+ }
+
+ if (mType == Notes.TYPE_NOTE) {
+ for (SqlData sqlData : mDataList) {
+ sqlData.commit(mId, validateVersion, mVersion);
+ }
+ }
+ }
+
+ // refresh local info
+ loadFromCursor(mId);
+ if (mType == Notes.TYPE_NOTE)
+ loadDataContent();
+
+ mDiffNoteValues.clear();
+ mIsCreate = false;
+ }
+}
diff --git a/src/src/app/src/main/java/net/micode/notes/gtask/data/Task.java b/src/src/app/src/main/java/net/micode/notes/gtask/data/Task.java
new file mode 100644
index 0000000..44408db
--- /dev/null
+++ b/src/src/app/src/main/java/net/micode/notes/gtask/data/Task.java
@@ -0,0 +1,355 @@
+/*
+ * Copyright (c) 2010-2011, The MiCode Open Source Community (www.micode.net)
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+
+package net.micode.notes.gtask.data;
+
+import android.database.Cursor;
+import android.text.TextUtils;
+import android.util.Log;
+
+import net.micode.notes.data.Notes;
+import net.micode.notes.data.Notes.DataColumns;
+import net.micode.notes.data.Notes.DataConstants;
+import net.micode.notes.data.Notes.NoteColumns;
+import net.micode.notes.gtask.exception.ActionFailureException;
+import net.micode.notes.tool.GTaskStringUtils;
+
+import org.json.JSONArray;
+import org.json.JSONException;
+import org.json.JSONObject;
+
+
+public class Task extends Node {
+ private static final String TAG = Task.class.getSimpleName();
+
+ private boolean mCompleted;
+
+ private String mNotes;
+
+ private JSONObject mMetaInfo;
+
+ private Task mPriorSibling;
+
+ private TaskList mParent;
+
+ public Task() {
+ super();
+ mCompleted = false;
+ mNotes = null;
+ mPriorSibling = null;
+ mParent = null;
+ mMetaInfo = null;
+ }
+
+ public JSONObject getCreateAction(int actionId) {
+ JSONObject js = new JSONObject();
+
+ try {
+ // action_type
+ js.put(GTaskStringUtils.GTASK_JSON_ACTION_TYPE,
+ GTaskStringUtils.GTASK_JSON_ACTION_TYPE_CREATE);
+
+ // action_id
+ js.put(GTaskStringUtils.GTASK_JSON_ACTION_ID, actionId);
+
+ // index
+ js.put(GTaskStringUtils.GTASK_JSON_INDEX, mParent.getChildTaskIndex(this));
+
+ // entity_delta
+ JSONObject entity = new JSONObject();
+ entity.put(GTaskStringUtils.GTASK_JSON_NAME, getName());
+ entity.put(GTaskStringUtils.GTASK_JSON_CREATOR_ID, "null");
+ entity.put(GTaskStringUtils.GTASK_JSON_ENTITY_TYPE,
+ GTaskStringUtils.GTASK_JSON_TYPE_TASK);
+ if (getNotes() != null) {
+ entity.put(GTaskStringUtils.GTASK_JSON_NOTES, getNotes());
+ }
+ js.put(GTaskStringUtils.GTASK_JSON_ENTITY_DELTA, entity);
+
+ // parent_id
+ js.put(GTaskStringUtils.GTASK_JSON_PARENT_ID, mParent.getGid());
+
+ // dest_parent_type
+ js.put(GTaskStringUtils.GTASK_JSON_DEST_PARENT_TYPE,
+ GTaskStringUtils.GTASK_JSON_TYPE_GROUP);
+
+ // list_id
+ js.put(GTaskStringUtils.GTASK_JSON_LIST_ID, mParent.getGid());
+
+ // prior_sibling_id
+ if (mPriorSibling != null) {
+ js.put(GTaskStringUtils.GTASK_JSON_PRIOR_SIBLING_ID, mPriorSibling.getGid());
+ }
+
+ } catch (JSONException e) {
+ Log.e(TAG, e.toString());
+ //e.printStackTrace();
+ throw new ActionFailureException("fail to generate task-create jsonobject");
+ }
+
+ return js;
+ }
+
+ public JSONObject getUpdateAction(int actionId) {
+ JSONObject js = new JSONObject();
+
+ try {
+ // action_type
+ js.put(GTaskStringUtils.GTASK_JSON_ACTION_TYPE,
+ GTaskStringUtils.GTASK_JSON_ACTION_TYPE_UPDATE);
+
+ // action_id
+ js.put(GTaskStringUtils.GTASK_JSON_ACTION_ID, actionId);
+
+ // id
+ js.put(GTaskStringUtils.GTASK_JSON_ID, getGid());
+
+ // entity_delta
+ JSONObject entity = new JSONObject();
+ entity.put(GTaskStringUtils.GTASK_JSON_NAME, getName());
+ if (getNotes() != null) {
+ entity.put(GTaskStringUtils.GTASK_JSON_NOTES, getNotes());
+ }
+ entity.put(GTaskStringUtils.GTASK_JSON_DELETED, getDeleted());
+ js.put(GTaskStringUtils.GTASK_JSON_ENTITY_DELTA, entity);
+
+ } catch (JSONException e) {
+ Log.e(TAG, e.toString());
+ //e.printStackTrace();
+ throw new ActionFailureException("fail to generate task-update jsonobject");
+ }
+
+ return js;
+ }
+
+ public void setContentByRemoteJSON(JSONObject js) {
+ if (js != null) {
+ try {
+ // id
+ if (js.has(GTaskStringUtils.GTASK_JSON_ID)) {
+ setGid(js.getString(GTaskStringUtils.GTASK_JSON_ID));
+ }
+
+ // last_modified
+ if (js.has(GTaskStringUtils.GTASK_JSON_LAST_MODIFIED)) {
+ setLastModified(js.getLong(GTaskStringUtils.GTASK_JSON_LAST_MODIFIED));
+ }
+
+ // name
+ if (js.has(GTaskStringUtils.GTASK_JSON_NAME)) {
+ setName(js.getString(GTaskStringUtils.GTASK_JSON_NAME));
+ }
+
+ // notes
+ if (js.has(GTaskStringUtils.GTASK_JSON_NOTES)) {
+ setNotes(js.getString(GTaskStringUtils.GTASK_JSON_NOTES));
+ }
+
+ // deleted
+ if (js.has(GTaskStringUtils.GTASK_JSON_DELETED)) {
+ setDeleted(js.getBoolean(GTaskStringUtils.GTASK_JSON_DELETED));
+ }
+
+ // completed
+ if (js.has(GTaskStringUtils.GTASK_JSON_COMPLETED)) {
+ setCompleted(js.getBoolean(GTaskStringUtils.GTASK_JSON_COMPLETED));
+ }
+ } catch (JSONException e) {
+ Log.e(TAG, e.toString());
+ //e.printStackTrace();
+ throw new ActionFailureException("fail to get task content from jsonobject");
+ }
+ }
+ }
+
+ public void setContentByLocalJSON(JSONObject js) {
+ if (js == null || !js.has(GTaskStringUtils.META_HEAD_NOTE)
+ || !js.has(GTaskStringUtils.META_HEAD_DATA)) {
+ Log.w(TAG, "setContentByLocalJSON: nothing is avaiable");
+ }
+
+ try {
+ if(js != null) {
+ JSONObject note = js.getJSONObject(GTaskStringUtils.META_HEAD_NOTE);
+ JSONArray dataArray = js.getJSONArray(GTaskStringUtils.META_HEAD_DATA);
+
+ if (note.getInt(NoteColumns.TYPE) != Notes.TYPE_NOTE) {
+ Log.e(TAG, "invalid type");
+ return;
+ }
+
+ for (int i = 0; i < dataArray.length(); i++) {
+ JSONObject data = dataArray.getJSONObject(i);
+ if (TextUtils.equals(data.getString(DataColumns.MIME_TYPE), DataConstants.NOTE)) {
+ setName(data.getString(DataColumns.CONTENT));
+ break;
+ }
+ }
+ }
+ else{
+ Log.e(TAG, "setContentByLocalJSON: js == null");
+ }
+ } catch (JSONException e) {
+ Log.e(TAG, e.toString());
+ //e.printStackTrace();
+ }
+ }
+
+ public JSONObject getLocalJSONFromContent() {
+ String name = getName();
+ try {
+ if (mMetaInfo == null) {
+ // new task created from web
+ if (name == null) {
+ Log.w(TAG, "the note seems to be an empty one");
+ return null;
+ }
+
+ JSONObject js = new JSONObject();
+ JSONObject note = new JSONObject();
+ JSONArray dataArray = new JSONArray();
+ JSONObject data = new JSONObject();
+ data.put(DataColumns.CONTENT, name);
+ dataArray.put(data);
+ js.put(GTaskStringUtils.META_HEAD_DATA, dataArray);
+ note.put(NoteColumns.TYPE, Notes.TYPE_NOTE);
+ js.put(GTaskStringUtils.META_HEAD_NOTE, note);
+ return js;
+ } else {
+ // synced task
+ JSONObject note = mMetaInfo.getJSONObject(GTaskStringUtils.META_HEAD_NOTE);
+ JSONArray dataArray = mMetaInfo.getJSONArray(GTaskStringUtils.META_HEAD_DATA);
+
+ for (int i = 0; i < dataArray.length(); i++) {
+ JSONObject data = dataArray.getJSONObject(i);
+ if (TextUtils.equals(data.getString(DataColumns.MIME_TYPE), DataConstants.NOTE)) {
+ data.put(DataColumns.CONTENT, getName());
+ break;
+ }
+ }
+
+ note.put(NoteColumns.TYPE, Notes.TYPE_NOTE);
+ return mMetaInfo;
+ }
+ } catch (JSONException e) {
+ Log.e(TAG, e.toString());
+ //e.printStackTrace();
+ return null;
+ }
+ }
+
+ public void setMetaInfo(MetaData metaData) {
+ if (metaData != null && metaData.getNotes() != null) {
+ try {
+ mMetaInfo = new JSONObject(metaData.getNotes());
+ } catch (JSONException e) {
+ Log.w(TAG, e.toString());
+ mMetaInfo = null;
+ }
+ }
+ }
+
+ public int getSyncAction(Cursor c) {
+ try {
+ JSONObject noteInfo = null;
+ if (mMetaInfo != null && mMetaInfo.has(GTaskStringUtils.META_HEAD_NOTE)) {
+ noteInfo = mMetaInfo.getJSONObject(GTaskStringUtils.META_HEAD_NOTE);
+ }
+
+ if (noteInfo == null) {
+ Log.w(TAG, "it seems that note meta has been deleted");
+ return SYNC_ACTION_UPDATE_REMOTE;
+ }
+
+ if (!noteInfo.has(NoteColumns.ID)) {
+ Log.w(TAG, "remote note id seems to be deleted");
+ return SYNC_ACTION_UPDATE_LOCAL;
+ }
+
+ // validate the note id now
+ if (c.getLong(SqlNote.ID_COLUMN) != noteInfo.getLong(NoteColumns.ID)) {
+ Log.w(TAG, "note id doesn't match");
+ return SYNC_ACTION_UPDATE_LOCAL;
+ }
+
+ if (c.getInt(SqlNote.LOCAL_MODIFIED_COLUMN) == 0) {
+ // there is no local update
+ if (c.getLong(SqlNote.SYNC_ID_COLUMN) == getLastModified()) {
+ // no update both side
+ return SYNC_ACTION_NONE;
+ } else {
+ // apply remote to local
+ return SYNC_ACTION_UPDATE_LOCAL;
+ }
+ } else {
+ // validate gtask id
+ if (!c.getString(SqlNote.GTASK_ID_COLUMN).equals(getGid())) {
+ Log.e(TAG, "gtask id doesn't match");
+ return SYNC_ACTION_ERROR;
+ }
+ if (c.getLong(SqlNote.SYNC_ID_COLUMN) == getLastModified()) {
+ // local modification only
+ return SYNC_ACTION_UPDATE_REMOTE;
+ } else {
+ return SYNC_ACTION_UPDATE_CONFLICT;
+ }
+ }
+ } catch (Exception e) {
+ Log.e(TAG, e.toString());
+ //e.printStackTrace();
+ }
+
+ return SYNC_ACTION_ERROR;
+ }
+
+ public boolean isWorthSaving() {
+ return mMetaInfo != null || (getName() != null && getName().trim().length() > 0)
+ || (getNotes() != null && getNotes().trim().length() > 0);
+ }
+
+ public void setCompleted(boolean completed) {
+ this.mCompleted = completed;
+ }
+
+ public void setNotes(String notes) {
+ this.mNotes = notes;
+ }
+
+ public void setPriorSibling(Task priorSibling) {
+ this.mPriorSibling = priorSibling;
+ }
+
+ public void setParent(TaskList parent) {
+ this.mParent = parent;
+ }
+
+ public boolean getCompleted() {
+ return this.mCompleted;
+ }
+
+ public String getNotes() {
+ return this.mNotes;
+ }
+
+ public Task getPriorSibling() {
+ return this.mPriorSibling;
+ }
+
+ public TaskList getParent() {
+ return this.mParent;
+ }
+
+}
diff --git a/src/src/app/src/main/java/net/micode/notes/gtask/data/TaskList.java b/src/src/app/src/main/java/net/micode/notes/gtask/data/TaskList.java
new file mode 100644
index 0000000..1611edf
--- /dev/null
+++ b/src/src/app/src/main/java/net/micode/notes/gtask/data/TaskList.java
@@ -0,0 +1,349 @@
+/*
+ * Copyright (c) 2010-2011, The MiCode Open Source Community (www.micode.net)
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+
+package net.micode.notes.gtask.data;
+
+import android.database.Cursor;
+import android.util.Log;
+
+import net.micode.notes.data.Notes;
+import net.micode.notes.data.Notes.NoteColumns;
+import net.micode.notes.gtask.exception.ActionFailureException;
+import net.micode.notes.tool.GTaskStringUtils;
+
+import org.json.JSONException;
+import org.json.JSONObject;
+
+import java.util.ArrayList;
+
+
+public class TaskList extends Node {
+ private static final String TAG = TaskList.class.getSimpleName();
+
+ private int mIndex;
+
+ private ArrayList mChildren;
+
+ public TaskList() {
+ super();
+ mChildren = new ArrayList();
+ mIndex = 1;
+ }
+
+ public JSONObject getCreateAction(int actionId) {
+ JSONObject js = new JSONObject();
+
+ try {
+ // action_type
+ js.put(GTaskStringUtils.GTASK_JSON_ACTION_TYPE,
+ GTaskStringUtils.GTASK_JSON_ACTION_TYPE_CREATE);
+
+ // action_id
+ js.put(GTaskStringUtils.GTASK_JSON_ACTION_ID, actionId);
+
+ // index
+ js.put(GTaskStringUtils.GTASK_JSON_INDEX, mIndex);
+
+ // entity_delta
+ JSONObject entity = new JSONObject();
+ entity.put(GTaskStringUtils.GTASK_JSON_NAME, getName());
+ entity.put(GTaskStringUtils.GTASK_JSON_CREATOR_ID, "null");
+ entity.put(GTaskStringUtils.GTASK_JSON_ENTITY_TYPE,
+ GTaskStringUtils.GTASK_JSON_TYPE_GROUP);
+ js.put(GTaskStringUtils.GTASK_JSON_ENTITY_DELTA, entity);
+
+ } catch (JSONException e) {
+ Log.e(TAG, e.toString());
+ //e.printStackTrace();
+ throw new ActionFailureException("fail to generate tasklist-create jsonobject");
+ }
+
+ return js;
+ }
+
+ public JSONObject getUpdateAction(int actionId) {
+ JSONObject js = new JSONObject();
+
+ try {
+ // action_type
+ js.put(GTaskStringUtils.GTASK_JSON_ACTION_TYPE,
+ GTaskStringUtils.GTASK_JSON_ACTION_TYPE_UPDATE);
+
+ // action_id
+ js.put(GTaskStringUtils.GTASK_JSON_ACTION_ID, actionId);
+
+ // id
+ js.put(GTaskStringUtils.GTASK_JSON_ID, getGid());
+
+ // entity_delta
+ JSONObject entity = new JSONObject();
+ entity.put(GTaskStringUtils.GTASK_JSON_NAME, getName());
+ entity.put(GTaskStringUtils.GTASK_JSON_DELETED, getDeleted());
+ js.put(GTaskStringUtils.GTASK_JSON_ENTITY_DELTA, entity);
+
+ } catch (JSONException e) {
+ Log.e(TAG, e.toString());
+ //e.printStackTrace();
+ throw new ActionFailureException("fail to generate tasklist-update jsonobject");
+ }
+
+ return js;
+ }
+
+ public void setContentByRemoteJSON(JSONObject js) {
+ if (js != null) {
+ try {
+ // id
+ if (js.has(GTaskStringUtils.GTASK_JSON_ID)) {
+ setGid(js.getString(GTaskStringUtils.GTASK_JSON_ID));
+ }
+
+ // last_modified
+ if (js.has(GTaskStringUtils.GTASK_JSON_LAST_MODIFIED)) {
+ setLastModified(js.getLong(GTaskStringUtils.GTASK_JSON_LAST_MODIFIED));
+ }
+
+ // name
+ if (js.has(GTaskStringUtils.GTASK_JSON_NAME)) {
+ setName(js.getString(GTaskStringUtils.GTASK_JSON_NAME));
+ }
+
+ } catch (JSONException e) {
+ Log.e(TAG, e.toString());
+ //e.printStackTrace();
+ throw new ActionFailureException("fail to get tasklist content from jsonobject");
+ }
+ }
+ }
+
+ public void setContentByLocalJSON(JSONObject js) {
+ if (js == null || !js.has(GTaskStringUtils.META_HEAD_NOTE)) {
+ Log.w(TAG, "setContentByLocalJSON: nothing is avaiable");
+ }
+ if(js != null) {
+ try {
+ JSONObject folder = js.getJSONObject(GTaskStringUtils.META_HEAD_NOTE);
+
+ if (folder.getInt(NoteColumns.TYPE) == Notes.TYPE_FOLDER) {
+ String name = folder.getString(NoteColumns.SNIPPET);
+ setName(GTaskStringUtils.MIUI_FOLDER_PREFFIX + name);
+ } else if (folder.getInt(NoteColumns.TYPE) == Notes.TYPE_SYSTEM) {
+ if (folder.getLong(NoteColumns.ID) == Notes.ID_ROOT_FOLDER)
+ setName(GTaskStringUtils.MIUI_FOLDER_PREFFIX + GTaskStringUtils.FOLDER_DEFAULT);
+ else if (folder.getLong(NoteColumns.ID) == Notes.ID_CALL_RECORD_FOLDER)
+ setName(GTaskStringUtils.MIUI_FOLDER_PREFFIX
+ + GTaskStringUtils.FOLDER_CALL_NOTE);
+ else
+ Log.e(TAG, "invalid system folder");
+ } else {
+ Log.e(TAG, "error type");
+ }
+ } catch (JSONException e) {
+ Log.e(TAG, e.toString());
+ //e.printStackTrace();
+ }
+ }
+ else{
+ Log.e(TAG, "setContentByLocalJSON: js == null" );
+ }
+ }
+
+ public JSONObject getLocalJSONFromContent() {
+ try {
+ JSONObject js = new JSONObject();
+ JSONObject folder = new JSONObject();
+
+ String folderName = getName();
+ if (getName().startsWith(GTaskStringUtils.MIUI_FOLDER_PREFFIX))
+ folderName = folderName.substring(GTaskStringUtils.MIUI_FOLDER_PREFFIX.length(),
+ folderName.length());
+ folder.put(NoteColumns.SNIPPET, folderName);
+ if (folderName.equals(GTaskStringUtils.FOLDER_DEFAULT)
+ || folderName.equals(GTaskStringUtils.FOLDER_CALL_NOTE))
+ folder.put(NoteColumns.TYPE, Notes.TYPE_SYSTEM);
+ else
+ folder.put(NoteColumns.TYPE, Notes.TYPE_FOLDER);
+
+ js.put(GTaskStringUtils.META_HEAD_NOTE, folder);
+
+ return js;
+ } catch (JSONException e) {
+ Log.e(TAG, e.toString());
+ //e.printStackTrace();
+ return null;
+ }
+ }
+
+ public int getSyncAction(Cursor c) {
+ try {
+ if (c.getInt(SqlNote.LOCAL_MODIFIED_COLUMN) == 0) {
+ // there is no local update
+ if (c.getLong(SqlNote.SYNC_ID_COLUMN) == getLastModified()) {
+ // no update both side
+ return SYNC_ACTION_NONE;
+ } else {
+ // apply remote to local
+ return SYNC_ACTION_UPDATE_LOCAL;
+ }
+ } else {
+ // validate gtask id
+ if (!c.getString(SqlNote.GTASK_ID_COLUMN).equals(getGid())) {
+ Log.e(TAG, "gtask id doesn't match");
+ return SYNC_ACTION_ERROR;
+ }
+
+ if (c.getLong(SqlNote.SYNC_ID_COLUMN) == getLastModified()) {
+ // local modification only
+ return SYNC_ACTION_UPDATE_REMOTE;
+ } else {
+ // for folder conflicts, just apply local modification
+ return SYNC_ACTION_UPDATE_LOCAL;
+ }
+
+ }
+ } catch (Exception e) {
+ Log.e(TAG, e.toString());
+ //e.printStackTrace();
+ }
+
+ return SYNC_ACTION_ERROR;
+ }
+
+ public int getChildTaskCount() {
+ return mChildren.size();
+ }
+
+ public boolean addChildTask(Task task) {
+ boolean ret = false;
+ if (task != null && !mChildren.contains(task)) {
+ ret = mChildren.add(task);
+ if (ret) {
+ // need to set prior sibling and parent
+ task.setPriorSibling(mChildren.isEmpty() ? null : mChildren
+ .get(mChildren.size() - 1));
+ task.setParent(this);
+ }
+ }
+ return ret;
+ }
+
+ public boolean addChildTask(Task task, int index) {
+ if (index < 0 || index > mChildren.size()) {
+ Log.e(TAG, "add child task: invalid index");
+ return false;
+ }
+
+ int pos = mChildren.indexOf(task);
+ if (task != null && pos == -1) {
+ mChildren.add(index, task);
+
+ // update the task list
+ Task preTask = null;
+ Task afterTask = null;
+ if (index != 0)
+ preTask = mChildren.get(index - 1);
+ if (index != mChildren.size() - 1)
+ afterTask = mChildren.get(index + 1);
+
+ task.setPriorSibling(preTask);
+ if (afterTask != null)
+ afterTask.setPriorSibling(task);
+ }
+
+ return true;
+ }
+
+ public boolean removeChildTask(Task task) {
+ boolean ret = false;
+ int index = mChildren.indexOf(task);
+ if (index != -1) {
+ ret = mChildren.remove(task);
+
+ if (ret) {
+ // reset prior sibling and parent
+ task.setPriorSibling(null);
+ task.setParent(null);
+
+ // update the task list
+ if (index != mChildren.size()) {
+ mChildren.get(index).setPriorSibling(
+ index == 0 ? null : mChildren.get(index - 1));
+ }
+ }
+ }
+ return ret;
+ }
+
+ public boolean moveChildTask(Task task, int index) {
+
+ if (index < 0 || index >= mChildren.size()) {
+ Log.e(TAG, "move child task: invalid index");
+ return false;
+ }
+
+ int pos = mChildren.indexOf(task);
+ if (pos == -1) {
+ Log.e(TAG, "move child task: the task should in the list");
+ return false;
+ }
+
+ if (pos == index)
+ return true;
+ return (removeChildTask(task) && addChildTask(task, index));
+ }
+
+ public Task findChildTaskByGid(String gid) {
+ for (int i = 0; i < mChildren.size(); i++) {
+ Task t = mChildren.get(i);
+ if (t.getGid().equals(gid)) {
+ return t;
+ }
+ }
+ return null;
+ }
+
+ public int getChildTaskIndex(Task task) {
+ return mChildren.indexOf(task);
+ }
+
+ public Task getChildTaskByIndex(int index) {
+ if (index < 0 || index >= mChildren.size()) {
+ Log.e(TAG, "getTaskByIndex: invalid index");
+ return null;
+ }
+ return mChildren.get(index);
+ }
+
+ public Task getChilTaskByGid(String gid) {
+ for (Task task : mChildren) {
+ if (task.getGid().equals(gid))
+ return task;
+ }
+ return null;
+ }
+
+ public ArrayList getChildTaskList() {
+ return this.mChildren;
+ }
+
+ public void setIndex(int index) {
+ this.mIndex = index;
+ }
+
+ public int getIndex() {
+ return this.mIndex;
+ }
+}
diff --git a/src/src/app/src/main/java/net/micode/notes/gtask/exception/ActionFailureException.java b/src/src/app/src/main/java/net/micode/notes/gtask/exception/ActionFailureException.java
new file mode 100644
index 0000000..15504be
--- /dev/null
+++ b/src/src/app/src/main/java/net/micode/notes/gtask/exception/ActionFailureException.java
@@ -0,0 +1,33 @@
+/*
+ * Copyright (c) 2010-2011, The MiCode Open Source Community (www.micode.net)
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+
+package net.micode.notes.gtask.exception;
+
+public class ActionFailureException extends RuntimeException {
+ private static final long serialVersionUID = 4425249765923293627L;
+
+ public ActionFailureException() {
+ super();
+ }
+
+ public ActionFailureException(String paramString) {
+ super(paramString);
+ }
+
+ public ActionFailureException(String paramString, Throwable paramThrowable) {
+ super(paramString, paramThrowable);
+ }
+}
diff --git a/src/src/app/src/main/java/net/micode/notes/gtask/exception/NetworkFailureException.java b/src/src/app/src/main/java/net/micode/notes/gtask/exception/NetworkFailureException.java
new file mode 100644
index 0000000..b08cfb1
--- /dev/null
+++ b/src/src/app/src/main/java/net/micode/notes/gtask/exception/NetworkFailureException.java
@@ -0,0 +1,33 @@
+/*
+ * Copyright (c) 2010-2011, The MiCode Open Source Community (www.micode.net)
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+
+package net.micode.notes.gtask.exception;
+
+public class NetworkFailureException extends Exception {
+ private static final long serialVersionUID = 2107610287180234136L;
+
+ public NetworkFailureException() {
+ super();
+ }
+
+ public NetworkFailureException(String paramString) {
+ super(paramString);
+ }
+
+ public NetworkFailureException(String paramString, Throwable paramThrowable) {
+ super(paramString, paramThrowable);
+ }
+}
diff --git a/src/src/app/src/main/java/net/micode/notes/gtask/remote/GTaskASyncTask.java b/src/src/app/src/main/java/net/micode/notes/gtask/remote/GTaskASyncTask.java
new file mode 100644
index 0000000..ad063dd
--- /dev/null
+++ b/src/src/app/src/main/java/net/micode/notes/gtask/remote/GTaskASyncTask.java
@@ -0,0 +1,136 @@
+
+/*
+ * Copyright (c) 2010-2011, The MiCode Open Source Community (www.micode.net)
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+
+package net.micode.notes.gtask.remote;
+
+import android.app.Notification;
+import android.app.NotificationManager;
+import android.app.PendingIntent;
+import android.content.Context;
+import android.content.Intent;
+import android.os.AsyncTask;
+
+import net.micode.notes.R;
+import net.micode.notes.ui.NotesListActivity;
+import net.micode.notes.ui.NotesPreferenceActivity;
+
+
+public class GTaskASyncTask extends AsyncTask {
+
+ private static int GTASK_SYNC_NOTIFICATION_ID = 5234235;
+
+ public interface OnCompleteListener {
+ void onComplete();
+ }
+
+ private Context mContext;
+
+ private NotificationManager mNotifiManager;
+
+ private GTaskManager mTaskManager;
+
+ private OnCompleteListener mOnCompleteListener;
+
+ public GTaskASyncTask(Context context, OnCompleteListener listener) {
+ mContext = context;
+ mOnCompleteListener = listener;
+ mNotifiManager = (NotificationManager) mContext
+ .getSystemService(Context.NOTIFICATION_SERVICE);
+ mTaskManager = GTaskManager.getInstance();
+ }
+
+ public void cancelSync() {
+ mTaskManager.cancelSync();
+ }
+
+ public void publishProgess(String message) {
+ publishProgress(new String[] {
+ message
+ });
+ }
+
+ private void showNotification(int tickerId, String content) {
+ Notification notification = new Notification(R.drawable.notification, mContext
+ .getString(tickerId), System.currentTimeMillis());
+ notification.defaults = Notification.DEFAULT_LIGHTS;
+ notification.flags = Notification.FLAG_AUTO_CANCEL;
+ PendingIntent pendingIntent;
+ if (tickerId != R.string.ticker_success) {
+ pendingIntent = PendingIntent.getActivity(mContext, 0, new Intent(mContext,
+ NotesPreferenceActivity.class), 0);
+
+ } else {
+ pendingIntent = PendingIntent.getActivity(mContext, 0, new Intent(mContext,
+ NotesListActivity.class), 0);
+ }
+ /* Notification.Builder builder1 = new Notification.Builder(mContext);
+ builder1.setSmallIcon(R.drawable.advise2); //设置图标
+ builder1.setTicker("显示第二个通知");
+ builder1.setContentTitle("通知"); //设置标题
+ builder1.setContentText("点击查看详细内容"); //消息内容
+ builder1.setWhen(System.currentTimeMillis()); //发送时间
+ builder1.setDefaults(Notification.DEFAULT_ALL); //设置默认的提示音,振动方式,灯光
+ builder1.setAutoCancel(true);//打开程序后图标消失
+ Intent intent =new Intent (MainActivity.this,Center.class);
+ PendingIntent pendingIntent =PendingIntent.getActivity(MainActivity.this, 0, intent, 0);
+ builder1.setContentIntent(pendingIntent);
+ Notification notification1 = builder1.build();
+ notificationManager.notify(124, notification1); // 通过通知管理器发送通知
+ notification.setLatestEventInfo(mContext, mContext.getString(R.string.app_name), content,
+ pendingIntent);*/
+ mNotifiManager.notify(GTASK_SYNC_NOTIFICATION_ID, notification);
+ }
+
+ @Override
+ protected Integer doInBackground(Void... unused) {
+ publishProgess(mContext.getString(R.string.sync_progress_login, NotesPreferenceActivity
+ .getSyncAccountName(mContext)));
+ return mTaskManager.sync(mContext, this);
+ }
+
+ @Override
+ protected void onProgressUpdate(String... progress) {
+ showNotification(R.string.ticker_syncing, progress[0]);
+ if (mContext instanceof GTaskSyncService) {
+ ((GTaskSyncService) mContext).sendBroadcast(progress[0]);
+ }
+ }
+
+ @Override
+ protected void onPostExecute(Integer result) {
+ if (result == GTaskManager.STATE_SUCCESS) {
+ showNotification(R.string.ticker_success, mContext.getString(
+ R.string.success_sync_account, mTaskManager.getSyncAccount()));
+ NotesPreferenceActivity.setLastSyncTime(mContext, System.currentTimeMillis());
+ } else if (result == GTaskManager.STATE_NETWORK_ERROR) {
+ showNotification(R.string.ticker_fail, mContext.getString(R.string.error_sync_network));
+ } else if (result == GTaskManager.STATE_INTERNAL_ERROR) {
+ showNotification(R.string.ticker_fail, mContext.getString(R.string.error_sync_internal));
+ } else if (result == GTaskManager.STATE_SYNC_CANCELLED) {
+ showNotification(R.string.ticker_cancel, mContext
+ .getString(R.string.error_sync_cancelled));
+ }
+ if (mOnCompleteListener != null) {
+ new Thread(new Runnable() {
+
+ public void run() {
+ mOnCompleteListener.onComplete();
+ }
+ }).start();
+ }
+ }
+}
diff --git a/src/src/app/src/main/java/net/micode/notes/gtask/remote/GTaskClient.java b/src/src/app/src/main/java/net/micode/notes/gtask/remote/GTaskClient.java
new file mode 100644
index 0000000..2ec2728
--- /dev/null
+++ b/src/src/app/src/main/java/net/micode/notes/gtask/remote/GTaskClient.java
@@ -0,0 +1,588 @@
+/*
+ * Copyright (c) 2010-2011, The MiCode Open Source Community (www.micode.net)
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+
+package net.micode.notes.gtask.remote;
+
+import android.accounts.Account;
+import android.accounts.AccountManager;
+import android.accounts.AccountManagerFuture;
+import android.annotation.TargetApi;
+import android.app.Activity;
+import android.os.Build;
+import android.os.Bundle;
+import android.text.TextUtils;
+import android.util.Log;
+
+import net.micode.notes.gtask.data.Node;
+import net.micode.notes.gtask.data.Task;
+import net.micode.notes.gtask.data.TaskList;
+import net.micode.notes.gtask.exception.ActionFailureException;
+import net.micode.notes.gtask.exception.NetworkFailureException;
+import net.micode.notes.tool.GTaskStringUtils;
+import net.micode.notes.ui.NotesPreferenceActivity;
+
+import org.apache.http.HttpEntity;
+import org.apache.http.HttpResponse;
+import org.apache.http.client.ClientProtocolException;
+import org.apache.http.client.entity.UrlEncodedFormEntity;
+import org.apache.http.client.methods.HttpGet;
+import org.apache.http.client.methods.HttpPost;
+import org.apache.http.cookie.Cookie;
+import org.apache.http.impl.client.BasicCookieStore;
+import org.apache.http.impl.client.DefaultHttpClient;
+import org.apache.http.message.BasicNameValuePair;
+import org.apache.http.params.BasicHttpParams;
+import org.apache.http.params.HttpConnectionParams;
+import org.apache.http.params.HttpParams;
+import org.apache.http.params.HttpProtocolParams;
+import org.json.JSONArray;
+import org.json.JSONException;
+import org.json.JSONObject;
+
+import java.io.BufferedReader;
+import java.io.IOException;
+import java.io.InputStream;
+import java.io.InputStreamReader;
+import java.util.LinkedList;
+import java.util.List;
+import java.util.zip.GZIPInputStream;
+import java.util.zip.Inflater;
+import java.util.zip.InflaterInputStream;
+
+
+public class GTaskClient {
+ private static final String TAG = GTaskClient.class.getSimpleName();
+
+ private static final String GTASK_URL = "https://mail.google.com/tasks/";
+
+ private static final String GTASK_GET_URL = "https://mail.google.com/tasks/ig";
+
+ private static final String GTASK_POST_URL = "https://mail.google.com/tasks/r/ig";
+
+ private static GTaskClient mInstance = null;
+
+ private DefaultHttpClient mHttpClient;
+
+ private String mGetUrl;
+
+ private String mPostUrl;
+
+ private long mClientVersion;
+
+ private boolean mLoggedin;
+
+ private long mLastLoginTime;
+
+ private int mActionId;
+
+ private Account mAccount;
+
+ private JSONArray mUpdateArray;
+
+ private GTaskClient() {
+ mHttpClient = null;
+ mGetUrl = GTASK_GET_URL;
+ mPostUrl = GTASK_POST_URL;
+ mClientVersion = -1;
+ mLoggedin = false;
+ mLastLoginTime = 0;
+ mActionId = 1;
+ mAccount = null;
+ mUpdateArray = null;
+ }
+
+ public static synchronized GTaskClient getInstance() {
+ if (mInstance == null) {
+ mInstance = new GTaskClient();
+ }
+ return mInstance;
+ }
+
+ public boolean login(Activity activity) {
+ // we suppose that the cookie would expire after 5 minutes
+ // then we need to re-login
+ long a = 1000;
+ long b = 60;
+ long c = 5;
+ final long interval = a * b * c;
+ if (mLastLoginTime + interval < System.currentTimeMillis()) {
+ mLoggedin = false;
+ }
+
+ // need to re-login after account switch
+ if (mLoggedin
+ && !TextUtils.equals(getSyncAccount().name, NotesPreferenceActivity
+ .getSyncAccountName(activity))) {
+ mLoggedin = false;
+ }
+
+ if (mLoggedin) {
+ Log.d(TAG, "already logged in");
+ return true;
+ }
+
+ mLastLoginTime = System.currentTimeMillis();
+ String authToken = loginGoogleAccount(activity, false);
+ if (authToken == null) {
+ Log.e(TAG, "login google account failed");
+ return false;
+ }
+
+ // login with custom domain if necessary
+ if (!(mAccount.name.toLowerCase().endsWith("gmail.com") || mAccount.name.toLowerCase()
+ .endsWith("googlemail.com"))) {
+ StringBuilder url = new StringBuilder(GTASK_URL).append("a/");
+ int index = mAccount.name.indexOf('@') + 1;
+ String suffix = mAccount.name.substring(index);
+ url.append(suffix + "/");
+ mGetUrl = url.toString() + "ig";
+ mPostUrl = url.toString() + "r/ig";
+
+ if (tryToLoginGtask(activity, authToken)) {
+ mLoggedin = true;
+ }
+ }
+
+ // try to login with google official url
+ if (!mLoggedin) {
+ mGetUrl = GTASK_GET_URL;
+ mPostUrl = GTASK_POST_URL;
+ if (!tryToLoginGtask(activity, authToken)) {
+ return false;
+ }
+ }
+
+ mLoggedin = true;
+ return true;
+ }
+
+ private String loginGoogleAccount(Activity activity, boolean invalidateToken) {
+ String authToken;
+ AccountManager accountManager = AccountManager.get(activity);
+ Account[] accounts = accountManager.getAccountsByType("com.google");
+
+ if (accounts.length == 0) {
+ Log.e(TAG, "there is no available google account");
+ return null;
+ }
+
+ String accountName = NotesPreferenceActivity.getSyncAccountName(activity);
+ Account account = null;
+ for (Account a : accounts) {
+ if (a.name.equals(accountName)) {
+ account = a;
+ break;
+ }
+ }
+ if (account != null) {
+ mAccount = account;
+ } else {
+ Log.e(TAG, "unable to get an account with the same name in the settings");
+ return null;
+ }
+
+ // get the token now
+ AccountManagerFuture accountManagerFuture = accountManager.getAuthToken(account,
+ "goanna_mobile", null, activity, null, null);
+ try {
+ Bundle authTokenBundle = accountManagerFuture.getResult();
+ authToken = authTokenBundle.getString(AccountManager.KEY_AUTHTOKEN);
+ if (invalidateToken) {
+ accountManager.invalidateAuthToken("com.google", authToken);
+ loginGoogleAccount(activity, false);
+ }
+ } catch (Exception e) {
+ Log.e(TAG, "get auth token failed");
+ authToken = null;
+ }
+
+ return authToken;
+ }
+
+ private boolean tryToLoginGtask(Activity activity, String authToken) {
+ if (!loginGtask(authToken)) {
+ // maybe the auth token is out of date, now let's invalidate the
+ // token and try again
+ authToken = loginGoogleAccount(activity, true);
+ if (authToken == null) {
+ Log.e(TAG, "login google account failed");
+ return false;
+ }
+
+ if (!loginGtask(authToken)) {
+ Log.e(TAG, "login gtask failed");
+ return false;
+ }
+ }
+ return true;
+ }
+
+ private boolean loginGtask(String authToken) {
+ int timeoutConnection = 10000;
+ int timeoutSocket = 15000;
+ HttpParams httpParameters = new BasicHttpParams();
+ HttpConnectionParams.setConnectionTimeout(httpParameters, timeoutConnection);
+ HttpConnectionParams.setSoTimeout(httpParameters, timeoutSocket);
+ mHttpClient = new DefaultHttpClient(httpParameters);
+ BasicCookieStore localBasicCookieStore = new BasicCookieStore();
+ mHttpClient.setCookieStore(localBasicCookieStore);
+ HttpProtocolParams.setUseExpectContinue(mHttpClient.getParams(), false);
+
+ // login gtask
+ try {
+ String loginUrl = mGetUrl + "?auth=" + authToken;
+ HttpGet httpGet = new HttpGet(loginUrl);
+ HttpResponse response = null;
+ response = mHttpClient.execute(httpGet);
+
+ // get the cookie now
+ List cookies = mHttpClient.getCookieStore().getCookies();
+ boolean hasAuthCookie = false;
+ for (Cookie cookie : cookies) {
+ if (cookie.getName().contains("GTL")) {
+ hasAuthCookie = true;
+ }
+ }
+ if (!hasAuthCookie) {
+ Log.w(TAG, "it seems that there is no auth cookie");
+ }
+
+ // get the client version
+ String resString = getResponseContent(response.getEntity());
+ String jsBegin = "_setup(";
+ String jsEnd = ")}";
+ int begin = resString.indexOf(jsBegin);
+ int end = resString.lastIndexOf(jsEnd);
+ String jsString = null;
+ if (begin != -1 && end != -1 && begin < end) {
+ jsString = resString.substring(begin + jsBegin.length(), end);
+ }
+ JSONObject js = new JSONObject(jsString);
+ mClientVersion = js.getLong("v");
+ } catch (JSONException e) {
+ Log.e(TAG, e.toString());
+ //e.printStackTrace();
+ return false;
+ } catch (Exception e) {
+ // simply catch all exceptions
+ Log.e(TAG, "httpget gtask_url failed");
+ return false;
+ }
+
+ return true;
+ }
+
+ private int getActionId() {
+ return mActionId++;
+ }
+
+ private HttpPost createHttpPost() {
+ HttpPost httpPost = new HttpPost(mPostUrl);
+ httpPost.setHeader("Content-Type", "application/x-www-form-urlencoded;charset=utf-8");
+ httpPost.setHeader("AT", "1");
+ return httpPost;
+ }
+
+ @TargetApi(Build.VERSION_CODES.KITKAT)
+ private String getResponseContent(HttpEntity entity) throws IOException {
+ String contentEncoding = null;
+ if (entity.getContentEncoding() != null) {
+ contentEncoding = entity.getContentEncoding().getValue();
+ Log.d(TAG, "encoding: " + contentEncoding);
+ }
+
+ InputStream input = entity.getContent();
+ if (contentEncoding != null && contentEncoding.equalsIgnoreCase("gzip")) {
+ input = new GZIPInputStream(entity.getContent());
+ } else if (contentEncoding != null && contentEncoding.equalsIgnoreCase("deflate")) {
+ Inflater inflater = new Inflater(true);
+ input = new InflaterInputStream(entity.getContent(), inflater);
+ }
+
+ try(InputStreamReader isr = new InputStreamReader(input); BufferedReader br = new BufferedReader(isr);) {
+ StringBuilder sb = new StringBuilder();
+ while (true) {
+ String buff = br.readLine();
+ if (buff == null) {
+ return sb.toString();
+ }
+ sb = sb.append(buff);
+ }
+ } finally {
+ input.close();
+ }
+ }
+
+ private JSONObject postRequest(JSONObject js) throws NetworkFailureException {
+ if (!mLoggedin) {
+ Log.e(TAG, "please login first");
+ throw new ActionFailureException("not logged in");
+ }
+
+ HttpPost httpPost = createHttpPost();
+ try {
+ LinkedList list = new LinkedList();
+ list.add(new BasicNameValuePair("r", js.toString()));
+ UrlEncodedFormEntity entity = new UrlEncodedFormEntity(list, "UTF-8");
+ httpPost.setEntity(entity);
+
+ // execute the post
+ HttpResponse response = mHttpClient.execute(httpPost);
+ String jsString = getResponseContent(response.getEntity());
+ return new JSONObject(jsString);
+
+ } catch (ClientProtocolException e) {
+ Log.e(TAG, e.toString());
+ //e.printStackTrace();
+ throw new NetworkFailureException("postRequest failed");
+ } catch (IOException e) {
+ Log.e(TAG, e.toString());
+ //e.printStackTrace();
+ throw new NetworkFailureException("postRequest failed");
+ } catch (JSONException e) {
+ Log.e(TAG, e.toString());
+ //e.printStackTrace();
+ throw new ActionFailureException("unable to convert response content to jsonobject");
+ } catch (Exception e) {
+ Log.e(TAG, e.toString());
+ //e.printStackTrace();
+ throw new ActionFailureException("error occurs when posting request");
+ }
+ }
+
+ public void createTask(Task task) throws NetworkFailureException {
+ commitUpdate();
+ try {
+ JSONObject jsPost = new JSONObject();
+ JSONArray actionList = new JSONArray();
+
+ // action_list
+ actionList.put(task.getCreateAction(getActionId()));
+ jsPost.put(GTaskStringUtils.GTASK_JSON_ACTION_LIST, actionList);
+
+ // client_version
+ jsPost.put(GTaskStringUtils.GTASK_JSON_CLIENT_VERSION, mClientVersion);
+
+ // post
+ JSONObject jsResponse = postRequest(jsPost);
+ JSONObject jsResult = (JSONObject) jsResponse.getJSONArray(
+ GTaskStringUtils.GTASK_JSON_RESULTS).get(0);
+ task.setGid(jsResult.getString(GTaskStringUtils.GTASK_JSON_NEW_ID));
+
+ } catch (JSONException e) {
+ Log.e(TAG, e.toString());
+ //e.printStackTrace();
+ throw new ActionFailureException("create task: handing jsonobject failed");
+ }
+ }
+
+ public void createTaskList(TaskList tasklist) throws NetworkFailureException {
+ commitUpdate();
+ try {
+ JSONObject jsPost = new JSONObject();
+ JSONArray actionList = new JSONArray();
+
+ // action_list
+ actionList.put(tasklist.getCreateAction(getActionId()));
+ jsPost.put(GTaskStringUtils.GTASK_JSON_ACTION_LIST, actionList);
+
+ // client version
+ jsPost.put(GTaskStringUtils.GTASK_JSON_CLIENT_VERSION, mClientVersion);
+
+ // post
+ JSONObject jsResponse = postRequest(jsPost);
+ JSONObject jsResult = (JSONObject) jsResponse.getJSONArray(
+ GTaskStringUtils.GTASK_JSON_RESULTS).get(0);
+ tasklist.setGid(jsResult.getString(GTaskStringUtils.GTASK_JSON_NEW_ID));
+
+ } catch (JSONException e) {
+ Log.e(TAG, e.toString());
+ //e.printStackTrace();
+ throw new ActionFailureException("create tasklist: handing jsonobject failed");
+ }
+ }
+
+ public void commitUpdate() throws NetworkFailureException {
+ if (mUpdateArray != null) {
+ try {
+ JSONObject jsPost = new JSONObject();
+
+ // action_list
+ jsPost.put(GTaskStringUtils.GTASK_JSON_ACTION_LIST, mUpdateArray);
+
+ // client_version
+ jsPost.put(GTaskStringUtils.GTASK_JSON_CLIENT_VERSION, mClientVersion);
+
+ postRequest(jsPost);
+ mUpdateArray = null;
+ } catch (JSONException e) {
+ Log.e(TAG, e.toString());
+ //e.printStackTrace();
+ throw new ActionFailureException("commit update: handing jsonobject failed");
+ }
+ }
+ }
+
+ public void addUpdateNode(Node node) throws NetworkFailureException {
+ if (node != null) {
+ // too many update items may result in an error
+ // set max to 10 items
+ if (mUpdateArray != null && mUpdateArray.length() > 10) {
+ commitUpdate();
+ }
+
+ if (mUpdateArray == null)
+ mUpdateArray = new JSONArray();
+ mUpdateArray.put(node.getUpdateAction(getActionId()));
+ }
+ }
+
+ public void moveTask(Task task, TaskList preParent, TaskList curParent)
+ throws NetworkFailureException {
+ commitUpdate();
+ try {
+ JSONObject jsPost = new JSONObject();
+ JSONArray actionList = new JSONArray();
+ JSONObject action = new JSONObject();
+
+ // action_list
+ action.put(GTaskStringUtils.GTASK_JSON_ACTION_TYPE,
+ GTaskStringUtils.GTASK_JSON_ACTION_TYPE_MOVE);
+ action.put(GTaskStringUtils.GTASK_JSON_ACTION_ID, getActionId());
+ action.put(GTaskStringUtils.GTASK_JSON_ID, task.getGid());
+ if (preParent == curParent && task.getPriorSibling() != null) {
+ // put prioring_sibing_id only if moving within the tasklist and
+ // it is not the first one
+ action.put(GTaskStringUtils.GTASK_JSON_PRIOR_SIBLING_ID, task.getPriorSibling());
+ }
+ action.put(GTaskStringUtils.GTASK_JSON_SOURCE_LIST, preParent.getGid());
+ action.put(GTaskStringUtils.GTASK_JSON_DEST_PARENT, curParent.getGid());
+ if (preParent != curParent) {
+ // put the dest_list only if moving between tasklists
+ action.put(GTaskStringUtils.GTASK_JSON_DEST_LIST, curParent.getGid());
+ }
+ actionList.put(action);
+ jsPost.put(GTaskStringUtils.GTASK_JSON_ACTION_LIST, actionList);
+
+ // client_version
+ jsPost.put(GTaskStringUtils.GTASK_JSON_CLIENT_VERSION, mClientVersion);
+
+ postRequest(jsPost);
+
+ } catch (JSONException e) {
+ Log.e(TAG, e.toString());
+ //e.printStackTrace();
+ throw new ActionFailureException("move task: handing jsonobject failed");
+ }
+ }
+
+ public void deleteNode(Node node) throws NetworkFailureException {
+ commitUpdate();
+ try {
+ JSONObject jsPost = new JSONObject();
+ JSONArray actionList = new JSONArray();
+
+ // action_list
+ node.setDeleted(true);
+ actionList.put(node.getUpdateAction(getActionId()));
+ jsPost.put(GTaskStringUtils.GTASK_JSON_ACTION_LIST, actionList);
+
+ // client_version
+ jsPost.put(GTaskStringUtils.GTASK_JSON_CLIENT_VERSION, mClientVersion);
+
+ postRequest(jsPost);
+ mUpdateArray = null;
+ } catch (JSONException e) {
+ Log.e(TAG, e.toString());
+ //e.printStackTrace();
+ throw new ActionFailureException("delete node: handing jsonobject failed");
+ }
+ }
+
+ public JSONArray getTaskLists() throws NetworkFailureException {
+ if (!mLoggedin) {
+ Log.e(TAG, "please login first");
+ throw new ActionFailureException("not logged in");
+ }
+
+ try {
+ HttpGet httpGet = new HttpGet(mGetUrl);
+ HttpResponse response = null;
+ response = mHttpClient.execute(httpGet);
+
+ // get the task list
+ String resString = getResponseContent(response.getEntity());
+ String jsBegin = "_setup(";
+ String jsEnd = ")}";
+ int begin = resString.indexOf(jsBegin);
+ int end = resString.lastIndexOf(jsEnd);
+ String jsString = null;
+ if (begin != -1 && end != -1 && begin < end) {
+ jsString = resString.substring(begin + jsBegin.length(), end);
+ }
+ JSONObject js = new JSONObject(jsString);
+ return js.getJSONObject("t").getJSONArray(GTaskStringUtils.GTASK_JSON_LISTS);
+ } catch (ClientProtocolException e) {
+ Log.e(TAG, e.toString());
+ //e.printStackTrace();
+ throw new NetworkFailureException("gettasklists: httpget failed");
+ } catch (IOException e) {
+ Log.e(TAG, e.toString());
+ //e.printStackTrace();
+ throw new NetworkFailureException("gettasklists: httpget failed");
+ } catch (JSONException e) {
+ Log.e(TAG, e.toString());
+ //e.printStackTrace();
+ throw new ActionFailureException("get task lists: handing jasonobject failed");
+ }
+ }
+
+ public JSONArray getTaskList(String listGid) throws NetworkFailureException {
+ commitUpdate();
+ try {
+ JSONObject jsPost = new JSONObject();
+ JSONArray actionList = new JSONArray();
+ JSONObject action = new JSONObject();
+
+ // action_list
+ action.put(GTaskStringUtils.GTASK_JSON_ACTION_TYPE,
+ GTaskStringUtils.GTASK_JSON_ACTION_TYPE_GETALL);
+ action.put(GTaskStringUtils.GTASK_JSON_ACTION_ID, getActionId());
+ action.put(GTaskStringUtils.GTASK_JSON_LIST_ID, listGid);
+ action.put(GTaskStringUtils.GTASK_JSON_GET_DELETED, false);
+ actionList.put(action);
+ jsPost.put(GTaskStringUtils.GTASK_JSON_ACTION_LIST, actionList);
+
+ // client_version
+ jsPost.put(GTaskStringUtils.GTASK_JSON_CLIENT_VERSION, mClientVersion);
+
+ JSONObject jsResponse = postRequest(jsPost);
+ return jsResponse.getJSONArray(GTaskStringUtils.GTASK_JSON_TASKS);
+ } catch (JSONException e) {
+ Log.e(TAG, e.toString());
+ //e.printStackTrace();
+ throw new ActionFailureException("get task list: handing jsonobject failed");
+ }
+ }
+
+ public Account getSyncAccount() {
+ return mAccount;
+ }
+
+ public void resetUpdateArray() {
+ mUpdateArray = null;
+ }
+}
diff --git a/src/src/app/src/main/java/net/micode/notes/gtask/remote/GTaskManager.java b/src/src/app/src/main/java/net/micode/notes/gtask/remote/GTaskManager.java
new file mode 100644
index 0000000..650d8f9
--- /dev/null
+++ b/src/src/app/src/main/java/net/micode/notes/gtask/remote/GTaskManager.java
@@ -0,0 +1,809 @@
+/*
+ * Copyright (c) 2010-2011, The MiCode Open Source Community (www.micode.net)
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+
+package net.micode.notes.gtask.remote;
+
+import android.app.Activity;
+import android.content.ContentResolver;
+import android.content.ContentUris;
+import android.content.ContentValues;
+import android.content.Context;
+import android.database.Cursor;
+import android.util.Log;
+
+import net.micode.notes.R;
+import net.micode.notes.data.Notes;
+import net.micode.notes.data.Notes.DataColumns;
+import net.micode.notes.data.Notes.NoteColumns;
+import net.micode.notes.gtask.data.MetaData;
+import net.micode.notes.gtask.data.Node;
+import net.micode.notes.gtask.data.SqlNote;
+import net.micode.notes.gtask.data.Task;
+import net.micode.notes.gtask.data.TaskList;
+import net.micode.notes.gtask.exception.ActionFailureException;
+import net.micode.notes.gtask.exception.NetworkFailureException;
+import net.micode.notes.tool.DataUtils;
+import net.micode.notes.tool.GTaskStringUtils;
+
+import org.json.JSONArray;
+import org.json.JSONException;
+import org.json.JSONObject;
+
+import java.util.HashMap;
+import java.util.HashSet;
+import java.util.Iterator;
+import java.util.Map;
+
+
+public class GTaskManager {
+ private static final String TAG = GTaskManager.class.getSimpleName();
+
+ public static final int STATE_SUCCESS = 0;
+
+ public static final int STATE_NETWORK_ERROR = 1;
+
+ public static final int STATE_INTERNAL_ERROR = 2;
+
+ public static final int STATE_SYNC_IN_PROGRESS = 3;
+
+ public static final int STATE_SYNC_CANCELLED = 4;
+
+ private static GTaskManager mInstance = null;
+
+ private Activity mActivity;
+
+ private Context mContext;
+
+ private ContentResolver mContentResolver;
+
+ private boolean mSyncing;
+
+ private boolean mCancelled;
+
+ private HashMap mGTaskListHashMap;
+
+ private HashMap mGTaskHashMap;
+
+ private HashMap mMetaHashMap;
+
+ private TaskList mMetaList;
+
+ private HashSet mLocalDeleteIdMap;
+
+ private HashMap mGidToNid;
+
+ private HashMap mNidToGid;
+
+ private GTaskManager() {
+ mSyncing = false;
+ mCancelled = false;
+ mGTaskListHashMap = new HashMap();
+ mGTaskHashMap = new HashMap();
+ mMetaHashMap = new HashMap();
+ mMetaList = null;
+ mLocalDeleteIdMap = new HashSet();
+ mGidToNid = new HashMap();
+ mNidToGid = new HashMap();
+ }
+
+ public static synchronized GTaskManager getInstance() {
+ if (mInstance == null) {
+ mInstance = new GTaskManager();
+ }
+ return mInstance;
+ }
+
+ public synchronized void setActivityContext(Activity activity) {
+ // used for getting authtoken
+ mActivity = activity;
+ }
+
+ public int sync(Context context, GTaskASyncTask asyncTask) {
+ if (mSyncing) {
+ Log.d(TAG, "Sync is in progress");
+ return STATE_SYNC_IN_PROGRESS;
+ }
+ mContext = context;
+ mContentResolver = mContext.getContentResolver();
+ mSyncing = true;
+ mCancelled = false;
+ mGTaskListHashMap.clear();
+ mGTaskHashMap.clear();
+ mMetaHashMap.clear();
+ mLocalDeleteIdMap.clear();
+ mGidToNid.clear();
+ mNidToGid.clear();
+
+ try {
+ GTaskClient client = GTaskClient.getInstance();
+ client.resetUpdateArray();
+
+ // login google task
+ if (!mCancelled) {
+ if (!client.login(mActivity)) {
+ throw new NetworkFailureException("login google task failed");
+ }
+ }
+
+ // get the task list from google
+ asyncTask.publishProgess(mContext.getString(R.string.sync_progress_init_list));
+ initGTaskList();
+
+ // do content sync work
+ asyncTask.publishProgess(mContext.getString(R.string.sync_progress_syncing));
+ syncContent();
+ } catch (NetworkFailureException e) {
+ Log.e(TAG, e.toString());
+ return STATE_NETWORK_ERROR;
+ } catch (ActionFailureException e) {
+ Log.e(TAG, e.toString());
+ return STATE_INTERNAL_ERROR;
+ } catch (Exception e) {
+ Log.e(TAG, e.toString());
+ //e.printStackTrace();
+ return STATE_INTERNAL_ERROR;
+ } finally {
+ mGTaskListHashMap.clear();
+ mGTaskHashMap.clear();
+ mMetaHashMap.clear();
+ mLocalDeleteIdMap.clear();
+ mGidToNid.clear();
+ mNidToGid.clear();
+ mSyncing = false;
+ }
+
+ return mCancelled ? STATE_SYNC_CANCELLED : STATE_SUCCESS;
+ }
+
+ private void initGTaskList() throws NetworkFailureException {
+ if (mCancelled)
+ return;
+ GTaskClient client = GTaskClient.getInstance();
+ try {
+ JSONArray jsTaskLists = client.getTaskLists();
+
+ // init meta list first
+ mMetaList = null;
+ for (int i = 0; i < jsTaskLists.length(); i++) {
+ JSONObject object = jsTaskLists.getJSONObject(i);
+ String gid = object.getString(GTaskStringUtils.GTASK_JSON_ID);
+ String name = object.getString(GTaskStringUtils.GTASK_JSON_NAME);
+
+ if (name
+ .equals(GTaskStringUtils.MIUI_FOLDER_PREFFIX + GTaskStringUtils.FOLDER_META)) {
+ mMetaList = new TaskList();
+ mMetaList.setContentByRemoteJSON(object);
+
+ // load meta data
+ JSONArray jsMetas = client.getTaskList(gid);
+ for (int j = 0; j < jsMetas.length(); j++) {
+ object = (JSONObject) jsMetas.getJSONObject(j);
+ MetaData metaData = new MetaData();
+ metaData.setContentByRemoteJSON(object);
+ if (metaData.isWorthSaving()) {
+ mMetaList.addChildTask(metaData);
+ if (metaData.getGid() != null) {
+ mMetaHashMap.put(metaData.getRelatedGid(), metaData);
+ }
+ }
+ }
+ }
+ }
+
+ // create meta list if not existed
+ if (mMetaList == null) {
+ mMetaList = new TaskList();
+ mMetaList.setName(GTaskStringUtils.MIUI_FOLDER_PREFFIX
+ + GTaskStringUtils.FOLDER_META);
+ GTaskClient.getInstance().createTaskList(mMetaList);
+ }
+
+ // init task list
+ for (int i = 0; i < jsTaskLists.length(); i++) {
+ JSONObject object = jsTaskLists.getJSONObject(i);
+ String gid = object.getString(GTaskStringUtils.GTASK_JSON_ID);
+ String name = object.getString(GTaskStringUtils.GTASK_JSON_NAME);
+
+ if (name.startsWith(GTaskStringUtils.MIUI_FOLDER_PREFFIX)
+ && !name.equals(GTaskStringUtils.MIUI_FOLDER_PREFFIX
+ + GTaskStringUtils.FOLDER_META)) {
+ TaskList tasklist = new TaskList();
+ tasklist.setContentByRemoteJSON(object);
+ mGTaskListHashMap.put(gid, tasklist);
+ mGTaskHashMap.put(gid, tasklist);
+
+ // load tasks
+ JSONArray jsTasks = client.getTaskList(gid);
+ for (int j = 0; j < jsTasks.length(); j++) {
+ object = (JSONObject) jsTasks.getJSONObject(j);
+ gid = object.getString(GTaskStringUtils.GTASK_JSON_ID);
+ Task task = new Task();
+ task.setContentByRemoteJSON(object);
+ if (task.isWorthSaving()) {
+ task.setMetaInfo(mMetaHashMap.get(gid));
+ tasklist.addChildTask(task);
+ mGTaskHashMap.put(gid, task);
+ }
+ }
+ }
+ }
+ } catch (JSONException e) {
+ Log.e(TAG, e.toString());
+ //e.printStackTrace();
+ throw new ActionFailureException("initGTaskList: handing JSONObject failed");
+ }
+ }
+
+ private void syncContent() throws NetworkFailureException {
+ int syncType;
+ Cursor c = null;
+ String gid;
+ Node node;
+
+ mLocalDeleteIdMap.clear();
+
+ if (mCancelled) {
+ return;
+ }
+
+ // for local deleted note
+ try {
+ c = mContentResolver.query(Notes.CONTENT_NOTE_URI, SqlNote.PROJECTION_NOTE,
+ "(type<>? AND parent_id=?)", new String[] {
+ String.valueOf(Notes.TYPE_SYSTEM), String.valueOf(Notes.ID_TRASH_FOLER)
+ }, null);
+ if (c != null) {
+ while (c.moveToNext()) {
+ gid = c.getString(SqlNote.GTASK_ID_COLUMN);
+ node = mGTaskHashMap.get(gid);
+ if (node != null) {
+ mGTaskHashMap.remove(gid);
+ doContentSync(Node.SYNC_ACTION_DEL_REMOTE, node, c);
+ }
+
+ mLocalDeleteIdMap.add(c.getLong(SqlNote.ID_COLUMN));
+ }
+ } else {
+ Log.w(TAG, "failed to query trash folder");
+ }
+ } finally {
+ if (c != null) {
+ c.close();
+ c = null;
+ }
+ }
+
+ // sync folder first
+ syncFolder();
+
+ // for note existing in database
+ try {
+ c = mContentResolver.query(Notes.CONTENT_NOTE_URI, SqlNote.PROJECTION_NOTE,
+ "(type=? AND parent_id<>?)", new String[] {
+ String.valueOf(Notes.TYPE_NOTE), String.valueOf(Notes.ID_TRASH_FOLER)
+ }, NoteColumns.TYPE + " DESC");
+ if (c != null) {
+ while (c.moveToNext()) {
+ gid = c.getString(SqlNote.GTASK_ID_COLUMN);
+ node = mGTaskHashMap.get(gid);
+ if (node != null) {
+ mGTaskHashMap.remove(gid);
+ mGidToNid.put(gid, c.getLong(SqlNote.ID_COLUMN));
+ mNidToGid.put(c.getLong(SqlNote.ID_COLUMN), gid);
+ syncType = node.getSyncAction(c);
+ } else {
+ if (c.getString(SqlNote.GTASK_ID_COLUMN).trim().length() == 0) {
+ // local add
+ syncType = Node.SYNC_ACTION_ADD_REMOTE;
+ } else {
+ // remote delete
+ syncType = Node.SYNC_ACTION_DEL_LOCAL;
+ }
+ }
+ doContentSync(syncType, node, c);
+ }
+ } else {
+ Log.w(TAG, "failed to query existing note in database");
+ }
+
+ } finally {
+ if (c != null) {
+ c.close();
+ c = null;
+ }
+ }
+
+ // go through remaining items
+ Iterator> iter = mGTaskHashMap.entrySet().iterator();
+ while (iter.hasNext()) {
+ Map.Entry entry = iter.next();
+ node = entry.getValue();
+ try {
+ doContentSync(Node.SYNC_ACTION_ADD_LOCAL, node, null);
+ }catch(NullPointerException e){
+ Log.d(TAG, "syncContent -> NullPointerException");
+ }
+
+ }
+
+ // mCancelled can be set by another thread, so we neet to check one by
+ // one
+ // clear local delete table
+ if (!mCancelled) {
+ if (!DataUtils.batchDeleteNotes(mContentResolver, mLocalDeleteIdMap)) {
+ throw new ActionFailureException("failed to batch-delete local deleted notes");
+ }
+ }
+
+ // refresh local sync id
+ if (!mCancelled) {
+ GTaskClient.getInstance().commitUpdate();
+ refreshLocalSyncId();
+ }
+
+ }
+
+ private void syncFolder() throws NetworkFailureException {
+ Cursor c = null;
+ String gid;
+ Node node;
+ int syncType;
+
+ if (mCancelled) {
+ return;
+ }
+
+ // for root folder
+ try {
+ c = mContentResolver.query(ContentUris.withAppendedId(Notes.CONTENT_NOTE_URI,
+ Notes.ID_ROOT_FOLDER), SqlNote.PROJECTION_NOTE, null, null, null);
+ if (c != null) {
+ c.moveToNext();
+ gid = c.getString(SqlNote.GTASK_ID_COLUMN);
+ node = mGTaskHashMap.get(gid);
+ if (node != null) {
+ mGTaskHashMap.remove(gid);
+ mGidToNid.put(gid, (long) Notes.ID_ROOT_FOLDER);
+ mNidToGid.put((long) Notes.ID_ROOT_FOLDER, gid);
+ // for system folder, only update remote name if necessary
+ if (!node.getName().equals(
+ GTaskStringUtils.MIUI_FOLDER_PREFFIX + GTaskStringUtils.FOLDER_DEFAULT))
+ doContentSync(Node.SYNC_ACTION_UPDATE_REMOTE, node, c);
+ } else {
+ doContentSync(Node.SYNC_ACTION_ADD_REMOTE, node, c);
+ }
+ } else {
+ Log.w(TAG, "failed to query root folder");
+ }
+ } finally {
+ if (c != null) {
+ c.close();
+ c = null;
+ }
+ }
+
+ // for call-note folder
+ try {
+ c = mContentResolver.query(Notes.CONTENT_NOTE_URI, SqlNote.PROJECTION_NOTE, "(_id=?)",
+ new String[] {
+ String.valueOf(Notes.ID_CALL_RECORD_FOLDER)
+ }, null);
+ if (c != null) {
+ if (c.moveToNext()) {
+ gid = c.getString(SqlNote.GTASK_ID_COLUMN);
+ node = mGTaskHashMap.get(gid);
+ if (node != null) {
+ mGTaskHashMap.remove(gid);
+ mGidToNid.put(gid, (long) Notes.ID_CALL_RECORD_FOLDER);
+ mNidToGid.put((long) Notes.ID_CALL_RECORD_FOLDER, gid);
+ // for system folder, only update remote name if
+ // necessary
+ if (!node.getName().equals(
+ GTaskStringUtils.MIUI_FOLDER_PREFFIX
+ + GTaskStringUtils.FOLDER_CALL_NOTE))
+ doContentSync(Node.SYNC_ACTION_UPDATE_REMOTE, node, c);
+ } else {
+ doContentSync(Node.SYNC_ACTION_ADD_REMOTE, node, c);
+ }
+ }
+ } else {
+ Log.w(TAG, "failed to query call note folder");
+ }
+ } finally {
+ if (c != null) {
+ c.close();
+ c = null;
+ }
+ }
+
+ // for local existing folders
+ try {
+ c = mContentResolver.query(Notes.CONTENT_NOTE_URI, SqlNote.PROJECTION_NOTE,
+ "(type=? AND parent_id<>?)", new String[] {
+ String.valueOf(Notes.TYPE_FOLDER), String.valueOf(Notes.ID_TRASH_FOLER)
+ }, NoteColumns.TYPE + " DESC");
+ if (c != null) {
+ while (c.moveToNext()) {
+ gid = c.getString(SqlNote.GTASK_ID_COLUMN);
+ node = mGTaskHashMap.get(gid);
+ if (node != null) {
+ mGTaskHashMap.remove(gid);
+ mGidToNid.put(gid, c.getLong(SqlNote.ID_COLUMN));
+ mNidToGid.put(c.getLong(SqlNote.ID_COLUMN), gid);
+ syncType = node.getSyncAction(c);
+ } else {
+ if (c.getString(SqlNote.GTASK_ID_COLUMN).trim().length() == 0) {
+ // local add
+ syncType = Node.SYNC_ACTION_ADD_REMOTE;
+ } else {
+ // remote delete
+ syncType = Node.SYNC_ACTION_DEL_LOCAL;
+ }
+ }
+ doContentSync(syncType, node, c);
+ }
+ } else {
+ Log.w(TAG, "failed to query existing folder");
+ }
+ } finally {
+ if (c != null) {
+ c.close();
+ c = null;
+ }
+ }
+
+ // for remote add folders
+ Iterator> iter = mGTaskListHashMap.entrySet().iterator();
+ while (iter.hasNext()) {
+ Map.Entry entry = iter.next();
+ gid = entry.getKey();
+ node = entry.getValue();
+ if (mGTaskHashMap.containsKey(gid)) {
+ mGTaskHashMap.remove(gid);
+ try {
+ doContentSync(Node.SYNC_ACTION_ADD_LOCAL, node, null);
+ }catch(NullPointerException e) {
+ Log.d(TAG, "syncFolder -> NullPointerException");
+ }
+ }
+ }
+
+ if (!mCancelled)
+ GTaskClient.getInstance().commitUpdate();
+ }
+
+ private void doContentSync(int syncType, Node node, Cursor c) throws NetworkFailureException {
+ if (mCancelled) {
+ return;
+ }
+
+ MetaData meta;
+ switch (syncType) {
+ case Node.SYNC_ACTION_ADD_LOCAL:
+ addLocalNode(node);
+ break;
+ case Node.SYNC_ACTION_ADD_REMOTE:
+ addRemoteNode(node, c);
+ break;
+ case Node.SYNC_ACTION_DEL_LOCAL:
+ meta = mMetaHashMap.get(c.getString(SqlNote.GTASK_ID_COLUMN));
+ if (meta != null) {
+ GTaskClient.getInstance().deleteNode(meta);
+ }
+ mLocalDeleteIdMap.add(c.getLong(SqlNote.ID_COLUMN));
+ break;
+ case Node.SYNC_ACTION_DEL_REMOTE:
+ meta = mMetaHashMap.get(node.getGid());
+ if (meta != null) {
+ GTaskClient.getInstance().deleteNode(meta);
+ }
+ GTaskClient.getInstance().deleteNode(node);
+ break;
+ case Node.SYNC_ACTION_UPDATE_LOCAL:
+ updateLocalNode(node, c);
+ break;
+ case Node.SYNC_ACTION_UPDATE_REMOTE:
+ updateRemoteNode(node, c);
+ break;
+ case Node.SYNC_ACTION_UPDATE_CONFLICT:
+ // merging both modifications maybe a good idea
+ // right now just use local update simply
+ updateRemoteNode(node, c);
+ break;
+ case Node.SYNC_ACTION_NONE:
+ break;
+ case Node.SYNC_ACTION_ERROR:
+ default:
+ throw new ActionFailureException("unkown sync action type");
+ }
+ }
+
+ private void addLocalNode(Node node) throws NetworkFailureException {
+ if (mCancelled) {
+ return;
+ }
+
+ SqlNote sqlNote;
+ if (node instanceof TaskList) {
+ if (node.getName().equals(
+ GTaskStringUtils.MIUI_FOLDER_PREFFIX + GTaskStringUtils.FOLDER_DEFAULT)) {
+ sqlNote = new SqlNote(mContext, Notes.ID_ROOT_FOLDER);
+ } else if (node.getName().equals(
+ GTaskStringUtils.MIUI_FOLDER_PREFFIX + GTaskStringUtils.FOLDER_CALL_NOTE)) {
+ sqlNote = new SqlNote(mContext, Notes.ID_CALL_RECORD_FOLDER);
+ } else {
+ sqlNote = new SqlNote(mContext);
+ sqlNote.setContent(node.getLocalJSONFromContent());
+ sqlNote.setParentId(Notes.ID_ROOT_FOLDER);
+ }
+ } else {
+ sqlNote = new SqlNote(mContext);
+ JSONObject js = node.getLocalJSONFromContent();
+ try {
+ if (js.has(GTaskStringUtils.META_HEAD_NOTE)) {
+ JSONObject note = js.getJSONObject(GTaskStringUtils.META_HEAD_NOTE);
+ if (note.has(NoteColumns.ID)) {
+ long id = note.getLong(NoteColumns.ID);
+ if (DataUtils.existInNoteDatabase(mContentResolver, id)) {
+ // the id is not available, have to create a new one
+ note.remove(NoteColumns.ID);
+ }
+ }
+ }
+
+ if (js.has(GTaskStringUtils.META_HEAD_DATA)) {
+ JSONArray dataArray = js.getJSONArray(GTaskStringUtils.META_HEAD_DATA);
+ for (int i = 0; i < dataArray.length(); i++) {
+ JSONObject data = dataArray.getJSONObject(i);
+ if (data.has(DataColumns.ID)) {
+ long dataId = data.getLong(DataColumns.ID);
+ if (DataUtils.existInDataDatabase(mContentResolver, dataId)) {
+ // the data id is not available, have to create
+ // a new one
+ data.remove(DataColumns.ID);
+ }
+ }
+ }
+
+ }
+ } catch (JSONException e) {
+ Log.w(TAG, e.toString());
+ //e.printStackTrace();
+ }
+ sqlNote.setContent(js);
+
+ Long parentId = mGidToNid.get(((Task) node).getParent().getGid());
+ if (parentId == null) {
+ Log.e(TAG, "cannot find task's parent id locally");
+ throw new ActionFailureException("cannot add local node");
+ }
+ sqlNote.setParentId(parentId.longValue());
+ }
+
+ // create the local node
+ sqlNote.setGtaskId(node.getGid());
+ sqlNote.commit(false);
+
+ // update gid-nid mapping
+ mGidToNid.put(node.getGid(), sqlNote.getId());
+ mNidToGid.put(sqlNote.getId(), node.getGid());
+
+ // update meta
+ updateRemoteMeta(node.getGid(), sqlNote);
+ }
+
+ private void updateLocalNode(Node node, Cursor c) throws NetworkFailureException {
+ if (mCancelled) {
+ return;
+ }
+
+ SqlNote sqlNote;
+ // update the note locally
+ sqlNote = new SqlNote(mContext, c);
+ sqlNote.setContent(node.getLocalJSONFromContent());
+
+ Long parentId = (node instanceof Task) ? mGidToNid.get(((Task) node).getParent().getGid())
+ : new Long(Notes.ID_ROOT_FOLDER);
+ if (parentId == null) {
+ Log.e(TAG, "cannot find task's parent id locally");
+ throw new ActionFailureException("cannot update local node");
+ }
+ sqlNote.setParentId(parentId.longValue());
+ sqlNote.commit(true);
+
+ // update meta info
+ updateRemoteMeta(node.getGid(), sqlNote);
+ }
+
+ private void addRemoteNode(Node node, Cursor c) throws NetworkFailureException {
+ if (mCancelled) {
+ return;
+ }
+
+ SqlNote sqlNote = new SqlNote(mContext, c);
+ Node n;
+
+ // update remotely
+ if (sqlNote.isNoteType()) {
+ Task task = new Task();
+ task.setContentByLocalJSON(sqlNote.getContent());
+
+ String parentGid = mNidToGid.get(sqlNote.getParentId());
+ if (parentGid == null) {
+ Log.e(TAG, "cannot find task's parent tasklist");
+ throw new ActionFailureException("cannot add remote task");
+ }
+ mGTaskListHashMap.get(parentGid).addChildTask(task);
+
+ GTaskClient.getInstance().createTask(task);
+ n = (Node) task;
+
+ // add meta
+ updateRemoteMeta(task.getGid(), sqlNote);
+ } else {
+ TaskList tasklist = null;
+
+ // we need to skip folder if it has already existed
+ String folderName = GTaskStringUtils.MIUI_FOLDER_PREFFIX;
+ if (sqlNote.getId() == Notes.ID_ROOT_FOLDER)
+ folderName += GTaskStringUtils.FOLDER_DEFAULT;
+ else if (sqlNote.getId() == Notes.ID_CALL_RECORD_FOLDER)
+ folderName += GTaskStringUtils.FOLDER_CALL_NOTE;
+ else
+ folderName += sqlNote.getSnippet();
+
+ Iterator> iter = mGTaskListHashMap.entrySet().iterator();
+ while (iter.hasNext()) {
+ Map.Entry entry = iter.next();
+ String gid = entry.getKey();
+ TaskList list = entry.getValue();
+
+ if (list.getName().equals(folderName)) {
+ tasklist = list;
+ if (mGTaskHashMap.containsKey(gid)) {
+ mGTaskHashMap.remove(gid);
+ }
+ break;
+ }
+ }
+
+ // no match we can add now
+ if (tasklist == null) {
+ tasklist = new TaskList();
+ tasklist.setContentByLocalJSON(sqlNote.getContent());
+ GTaskClient.getInstance().createTaskList(tasklist);
+ mGTaskListHashMap.put(tasklist.getGid(), tasklist);
+ }
+ n = (Node) tasklist;
+ }
+
+ // update local note
+ sqlNote.setGtaskId(n.getGid());
+ sqlNote.commit(false);
+ sqlNote.resetLocalModified();
+ sqlNote.commit(true);
+
+ // gid-id mapping
+ mGidToNid.put(n.getGid(), sqlNote.getId());
+ mNidToGid.put(sqlNote.getId(), n.getGid());
+ }
+
+ private void updateRemoteNode(Node node, Cursor c) throws NetworkFailureException {
+ if (mCancelled) {
+ return;
+ }
+
+ SqlNote sqlNote = new SqlNote(mContext, c);
+
+ // update remotely
+ node.setContentByLocalJSON(sqlNote.getContent());
+ GTaskClient.getInstance().addUpdateNode(node);
+
+ // update meta
+ updateRemoteMeta(node.getGid(), sqlNote);
+
+ // move task if necessary
+ if (sqlNote.isNoteType()) {
+ Task task = (Task) node;
+ TaskList preParentList = task.getParent();
+
+ String curParentGid = mNidToGid.get(sqlNote.getParentId());
+ if (curParentGid == null) {
+ Log.e(TAG, "cannot find task's parent tasklist");
+ throw new ActionFailureException("cannot update remote task");
+ }
+ TaskList curParentList = mGTaskListHashMap.get(curParentGid);
+
+ if (preParentList != curParentList) {
+ preParentList.removeChildTask(task);
+ curParentList.addChildTask(task);
+ GTaskClient.getInstance().moveTask(task, preParentList, curParentList);
+ }
+ }
+
+ // clear local modified flag
+ sqlNote.resetLocalModified();
+ sqlNote.commit(true);
+ }
+
+ private void updateRemoteMeta(String gid, SqlNote sqlNote) throws NetworkFailureException {
+ if (sqlNote != null && sqlNote.isNoteType()) {
+ MetaData metaData = mMetaHashMap.get(gid);
+ if (metaData != null) {
+ metaData.setMeta(gid, sqlNote.getContent());
+ GTaskClient.getInstance().addUpdateNode(metaData);
+ } else {
+ metaData = new MetaData();
+ metaData.setMeta(gid, sqlNote.getContent());
+ mMetaList.addChildTask(metaData);
+ mMetaHashMap.put(gid, metaData);
+ GTaskClient.getInstance().createTask(metaData);
+ }
+ }
+ }
+
+ private void refreshLocalSyncId() throws NetworkFailureException {
+ if (mCancelled) {
+ return;
+ }
+
+ // get the latest gtask list
+ mGTaskHashMap.clear();
+ mGTaskListHashMap.clear();
+ mMetaHashMap.clear();
+ initGTaskList();
+
+ Cursor c = null;
+ try {
+ c = mContentResolver.query(Notes.CONTENT_NOTE_URI, SqlNote.PROJECTION_NOTE,
+ "(type<>? AND parent_id<>?)", new String[] {
+ String.valueOf(Notes.TYPE_SYSTEM), String.valueOf(Notes.ID_TRASH_FOLER)
+ }, NoteColumns.TYPE + " DESC");
+ if (c != null) {
+ while (c.moveToNext()) {
+ String gid = c.getString(SqlNote.GTASK_ID_COLUMN);
+ Node node = mGTaskHashMap.get(gid);
+ if (node != null) {
+ mGTaskHashMap.remove(gid);
+ ContentValues values = new ContentValues();
+ values.put(NoteColumns.SYNC_ID, node.getLastModified());
+ mContentResolver.update(ContentUris.withAppendedId(Notes.CONTENT_NOTE_URI,
+ c.getLong(SqlNote.ID_COLUMN)), values, null, null);
+ } else {
+ Log.e(TAG, "something is missed");
+ throw new ActionFailureException(
+ "some local items don't have gid after sync");
+ }
+ }
+ } else {
+ Log.w(TAG, "failed to query local note to refresh sync id");
+ }
+ } finally {
+ if (c != null) {
+ c.close();
+ c = null;
+ }
+ }
+ }
+
+ public String getSyncAccount() {
+ return GTaskClient.getInstance().getSyncAccount().name;
+ }
+
+ public void cancelSync() {
+ mCancelled = true;
+ }
+}
diff --git a/src/src/app/src/main/java/net/micode/notes/gtask/remote/GTaskSyncService.java b/src/src/app/src/main/java/net/micode/notes/gtask/remote/GTaskSyncService.java
new file mode 100644
index 0000000..9baa4ff
--- /dev/null
+++ b/src/src/app/src/main/java/net/micode/notes/gtask/remote/GTaskSyncService.java
@@ -0,0 +1,128 @@
+/*
+ * Copyright (c) 2010-2011, The MiCode Open Source Community (www.micode.net)
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+
+package net.micode.notes.gtask.remote;
+
+import android.app.Activity;
+import android.app.Service;
+import android.content.Context;
+import android.content.Intent;
+import android.os.Bundle;
+import android.os.IBinder;
+
+public class GTaskSyncService extends Service {
+ public final static String ACTION_STRING_NAME = "sync_action_type";
+
+ public final static int ACTION_START_SYNC = 0;
+
+ public final static int ACTION_CANCEL_SYNC = 1;
+
+ public final static int ACTION_INVALID = 2;
+
+ public final static String GTASK_SERVICE_BROADCAST_NAME = "net.micode.notes.gtask.remote.gtask_sync_service";
+
+ public final static String GTASK_SERVICE_BROADCAST_IS_SYNCING = "isSyncing";
+
+ public final static String GTASK_SERVICE_BROADCAST_PROGRESS_MSG = "progressMsg";
+
+ private static GTaskASyncTask mSyncTask = null;
+
+ private static String mSyncProgress = "";
+
+ private synchronized void startSync() {//防止多线程调用报错
+ if (mSyncTask == null) {
+ mSyncTask = new GTaskASyncTask(this, new GTaskASyncTask.OnCompleteListener() {
+ public synchronized void onComplete() {
+ mSyncTask = null;
+ sendBroadcast("");
+ stopSelf();
+ }
+ });
+ sendBroadcast("");
+ mSyncTask.execute();
+ }
+ }
+
+ private void cancelSync() {
+ if (mSyncTask != null) {
+ mSyncTask.cancelSync();
+ }
+ }
+
+ @Override
+ public synchronized void onCreate() {
+ mSyncTask = null;
+ }
+
+ @Override
+ public int onStartCommand(Intent intent, int flags, int startId) {
+ Bundle bundle = intent.getExtras();
+ if (bundle != null && bundle.containsKey(ACTION_STRING_NAME)) {
+ switch (bundle.getInt(ACTION_STRING_NAME, ACTION_INVALID)) {
+ case ACTION_START_SYNC:
+ startSync();
+ break;
+ case ACTION_CANCEL_SYNC:
+ cancelSync();
+ break;
+ default:
+ break;
+ }
+ return START_STICKY;
+ }
+ return super.onStartCommand(intent, flags, startId);
+ }
+
+ @Override
+ public void onLowMemory() {
+ if (mSyncTask != null) {
+ mSyncTask.cancelSync();
+ }
+ }
+
+ public IBinder onBind(Intent intent) {
+ return null;
+ }
+
+ public synchronized void sendBroadcast(String msg) {
+ mSyncProgress = msg;
+ Intent intent = new Intent(GTASK_SERVICE_BROADCAST_NAME);
+ intent.putExtra(GTASK_SERVICE_BROADCAST_IS_SYNCING, mSyncTask != null);
+ intent.putExtra(GTASK_SERVICE_BROADCAST_PROGRESS_MSG, msg);
+ sendBroadcast(intent);
+ }
+
+ public static void startSync(Activity activity) {
+ GTaskManager.getInstance().setActivityContext(activity);
+ Intent intent = new Intent(activity, GTaskSyncService.class);
+ intent.putExtra(GTaskSyncService.ACTION_STRING_NAME, GTaskSyncService.ACTION_START_SYNC);
+ activity.startService(intent);
+ }
+
+ public static void cancelSync(Context context) {
+ Intent intent = new Intent(context, GTaskSyncService.class);
+ intent.putExtra(GTaskSyncService.ACTION_STRING_NAME, GTaskSyncService.ACTION_CANCEL_SYNC);
+ context.startService(intent);
+ }
+
+ public static boolean isSyncing() {
+ return mSyncTask != null;
+ }
+
+ public static String getProgressString() {
+ return mSyncProgress;
+ }
+}
diff --git a/src/src/app/src/main/java/net/micode/notes/model/Note.java b/src/src/app/src/main/java/net/micode/notes/model/Note.java
new file mode 100644
index 0000000..5417205
--- /dev/null
+++ b/src/src/app/src/main/java/net/micode/notes/model/Note.java
@@ -0,0 +1,253 @@
+/*
+ * Copyright (c) 2010-2011, The MiCode Open Source Community (www.micode.net)
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+
+package net.micode.notes.model;
+import android.content.ContentProviderOperation;
+import android.content.ContentProviderResult;
+import android.content.ContentUris;
+import android.content.ContentValues;
+import android.content.Context;
+import android.content.OperationApplicationException;
+import android.net.Uri;
+import android.os.RemoteException;
+import android.util.Log;
+
+import net.micode.notes.data.Notes;
+import net.micode.notes.data.Notes.CallNote;
+import net.micode.notes.data.Notes.DataColumns;
+import net.micode.notes.data.Notes.NoteColumns;
+import net.micode.notes.data.Notes.TextNote;
+
+import java.util.ArrayList;
+
+
+public class Note {
+ private ContentValues mNoteDiffValues;
+ private NoteData mNoteData;
+ private static final String TAG = "Note";
+ /**
+ * Create a new note id for adding a new note to databases
+ */
+ public static synchronized long getNewNoteId(Context context, long folderId) {
+ // Create a new note in the database
+ ContentValues values = new ContentValues();
+ long createdTime = System.currentTimeMillis();
+ values.put(NoteColumns.CREATED_DATE, createdTime);
+ values.put(NoteColumns.MODIFIED_DATE, createdTime);
+ values.put(NoteColumns.TYPE, Notes.TYPE_NOTE);
+ values.put(NoteColumns.LOCAL_MODIFIED, 1);
+ values.put(NoteColumns.PARENT_ID, folderId);
+ Uri uri = context.getContentResolver().insert(Notes.CONTENT_NOTE_URI, values);
+
+ long noteId = 0;
+ try {
+ noteId = Long.valueOf(uri.getPathSegments().get(1));
+ } catch (NumberFormatException e) {
+ Log.e(TAG, "Get note id error :" + e.toString());
+ noteId = 0;
+ }
+ if (noteId == -1) {
+ throw new IllegalStateException("Wrong note id:" + noteId);
+ }
+ return noteId;
+ }
+
+ public Note() {
+ mNoteDiffValues = new ContentValues();
+ mNoteData = new NoteData();
+ }
+
+ public void setNoteValue(String key, String value) {//使用这个加密码
+ mNoteDiffValues.put(key, value);
+ mNoteDiffValues.put(NoteColumns.LOCAL_MODIFIED, 1);
+ mNoteDiffValues.put(NoteColumns.MODIFIED_DATE, System.currentTimeMillis());
+ }
+
+ public void setTextData(String key, String value) {
+ mNoteData.setTextData(key, value);
+ }
+
+ public void setTextDataId(long id) {
+ mNoteData.setTextDataId(id);
+ }
+
+ public long getTextDataId() {
+ return mNoteData.mTextDataId;
+ }
+
+ public void setCallDataId(long id) {
+ mNoteData.setCallDataId(id);
+ }
+
+ public void setCallData(String key, String value) {
+ mNoteData.setCallData(key, value);
+ }
+
+ public boolean isLocalModified() {
+ return mNoteDiffValues.size() > 0 || mNoteData.isLocalModified();
+ }
+
+ public boolean syncNote(Context context, long noteId) {
+ if (noteId <= 0) {
+ throw new IllegalArgumentException("Wrong note id:" + noteId);
+ }
+
+ if (!isLocalModified()) {
+ return true;
+ }
+
+ /**
+ * In theory, once data changed, the note should be updated on {@link NoteColumns#LOCAL_MODIFIED} and
+ * {@link NoteColumns#MODIFIED_DATE}. For data safety, though update note fails, we also update the
+ * note data info
+ */
+ if (context.getContentResolver().update(
+ ContentUris.withAppendedId(Notes.CONTENT_NOTE_URI, noteId), mNoteDiffValues, null,
+ null) == 0) {
+ Log.e(TAG, "Update note error, should not happen");
+ // Do not return, fall through
+ }
+ mNoteDiffValues.clear();
+
+ if (mNoteData.isLocalModified()
+ && (mNoteData.pushIntoContentResolver(context, noteId) == null)) {
+ return false;
+ }
+
+ return true;
+ }
+
+ private class NoteData {
+ private long mTextDataId;
+
+ private ContentValues mTextDataValues;
+
+ private long mCallDataId;
+
+ private ContentValues mCallDataValues;
+
+ private static final String TAG = "NoteData";
+
+ public NoteData() {
+ mTextDataValues = new ContentValues();
+ mCallDataValues = new ContentValues();
+ mTextDataId = 0;
+ mCallDataId = 0;
+ }
+
+ boolean isLocalModified() {
+ return mTextDataValues.size() > 0 || mCallDataValues.size() > 0;
+ }
+
+ void setTextDataId(long id) {
+ if(id <= 0) {
+ throw new IllegalArgumentException("Text data id should larger than 0");
+ }
+ mTextDataId = id;
+ }
+
+ void setCallDataId(long id) {
+ if (id <= 0) {
+ throw new IllegalArgumentException("Call data id should larger than 0");
+ }
+ mCallDataId = id;
+ }
+
+ void setCallData(String key, String value) {
+ mCallDataValues.put(key, value);
+ mNoteDiffValues.put(NoteColumns.LOCAL_MODIFIED, 1);
+ mNoteDiffValues.put(NoteColumns.MODIFIED_DATE, System.currentTimeMillis());
+ }
+
+ void setTextData(String key, String value) {
+ mTextDataValues.put(key, value);
+ mNoteDiffValues.put(NoteColumns.LOCAL_MODIFIED, 1);
+ mNoteDiffValues.put(NoteColumns.MODIFIED_DATE, System.currentTimeMillis());//设置改变的时间
+ }
+
+ Uri pushIntoContentResolver(Context context, long noteId) {
+ /**
+ * Check for safety
+ */
+ if (noteId <= 0) {
+ throw new IllegalArgumentException("Wrong note id:" + noteId);
+ }
+
+ ArrayList operationList = new ArrayList();
+ ContentProviderOperation.Builder builder = null;
+
+ if(mTextDataValues.size() > 0) {
+ mTextDataValues.put(DataColumns.NOTE_ID, noteId);
+ if (mTextDataId == 0) {
+ mTextDataValues.put(DataColumns.MIME_TYPE, TextNote.CONTENT_ITEM_TYPE);
+ Uri uri = context.getContentResolver().insert(Notes.CONTENT_DATA_URI,
+ mTextDataValues);
+ try {
+ setTextDataId(Long.valueOf(uri.getPathSegments().get(1)));
+ } catch (NumberFormatException e) {
+ Log.e(TAG, "Insert new text data fail with noteId" + noteId);
+ mTextDataValues.clear();
+ return null;
+ }
+ } else {
+ builder = ContentProviderOperation.newUpdate(ContentUris.withAppendedId(
+ Notes.CONTENT_DATA_URI, mTextDataId));
+ builder.withValues(mTextDataValues);
+ operationList.add(builder.build());
+ }
+ mTextDataValues.clear();
+ }
+
+ if(mCallDataValues.size() > 0) {
+ mCallDataValues.put(DataColumns.NOTE_ID, noteId);
+ if (mCallDataId == 0) {
+ mCallDataValues.put(DataColumns.MIME_TYPE, CallNote.CONTENT_ITEM_TYPE);
+ Uri uri = context.getContentResolver().insert(Notes.CONTENT_DATA_URI,
+ mCallDataValues);
+ try {
+ setCallDataId(Long.valueOf(uri.getPathSegments().get(1)));
+ } catch (NumberFormatException e) {
+ Log.e(TAG, "Insert new call data fail with noteId" + noteId);
+ mCallDataValues.clear();
+ return null;
+ }
+ } else {
+ builder = ContentProviderOperation.newUpdate(ContentUris.withAppendedId(
+ Notes.CONTENT_DATA_URI, mCallDataId));
+ builder.withValues(mCallDataValues);
+ operationList.add(builder.build());
+ }
+ mCallDataValues.clear();
+ }
+
+ if (operationList.size() > 0) {
+ try {
+ ContentProviderResult[] results = context.getContentResolver().applyBatch(
+ Notes.AUTHORITY, operationList);
+ return (results == null || results.length == 0 || results[0] == null) ? null
+ : ContentUris.withAppendedId(Notes.CONTENT_NOTE_URI, noteId);
+ } catch (RemoteException e) {
+ Log.e(TAG, String.format("%s: %s", e.toString(), e.getMessage()));
+ return null;
+ } catch (OperationApplicationException e) {
+ Log.e(TAG, String.format("%s: %s", e.toString(), e.getMessage()));
+ return null;
+ }
+ }
+ return null;
+ }
+ }
+}
diff --git a/src/src/app/src/main/java/net/micode/notes/model/WorkingNote.java b/src/src/app/src/main/java/net/micode/notes/model/WorkingNote.java
new file mode 100644
index 0000000..22d0eea
--- /dev/null
+++ b/src/src/app/src/main/java/net/micode/notes/model/WorkingNote.java
@@ -0,0 +1,395 @@
+/*
+ * Copyright (c) 2010-2011, The MiCode Open Source Community (www.micode.net)
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+
+package net.micode.notes.model;
+
+import android.appwidget.AppWidgetManager;
+import android.content.ContentUris;
+import android.content.Context;
+import android.database.Cursor;
+import android.text.TextUtils;
+import android.util.Log;
+
+import net.micode.notes.data.Notes;
+import net.micode.notes.data.Notes.CallNote;
+import net.micode.notes.data.Notes.DataColumns;
+import net.micode.notes.data.Notes.DataConstants;
+import net.micode.notes.data.Notes.NoteColumns;
+import net.micode.notes.data.Notes.TextNote;
+import net.micode.notes.tool.ResourceParser.NoteBgResources;
+
+import java.security.NoSuchAlgorithmException;
+
+
+public class WorkingNote {
+ // Note for the working note
+ private Note mNote;
+ // Note Id
+ private long mNoteId;
+ // Note content
+ private String mContent;
+ // Note mode
+ private int mMode;
+
+ private long mAlertDate;
+
+ private long mModifiedDate;
+
+ private int mBgColorId;
+
+ private int mWidgetId;
+
+ private int mWidgetType;
+
+ private long mFolderId;
+
+ private Context mContext;
+
+ private static final String TAG = "WorkingNote";
+
+ private boolean mIsDeleted;
+
+ private NoteSettingChangedListener mNoteSettingStatusListener;
+
+ public static final String[] DATA_PROJECTION = new String[] {
+ DataColumns.ID,
+ DataColumns.CONTENT,
+ DataColumns.MIME_TYPE,
+ DataColumns.DATA1,
+ DataColumns.DATA2,
+ DataColumns.DATA3,
+ DataColumns.DATA4,
+ };
+
+ public static final String[] NOTE_PROJECTION = new String[] {
+ NoteColumns.PARENT_ID,
+ NoteColumns.ALERTED_DATE,
+ NoteColumns.BG_COLOR_ID,
+ NoteColumns.WIDGET_ID,
+ NoteColumns.WIDGET_TYPE,
+ NoteColumns.MODIFIED_DATE
+ };
+
+ private static final int DATA_ID_COLUMN = 0;
+
+ private static final int DATA_CONTENT_COLUMN = 1;
+
+ private static final int DATA_MIME_TYPE_COLUMN = 2;
+
+ private static final int DATA_MODE_COLUMN = 3;
+
+ private static final int NOTE_PARENT_ID_COLUMN = 0;
+
+ private static final int NOTE_ALERTED_DATE_COLUMN = 1;
+
+ private static final int NOTE_BG_COLOR_ID_COLUMN = 2;
+
+ private static final int NOTE_WIDGET_ID_COLUMN = 3;
+
+ private static final int NOTE_WIDGET_TYPE_COLUMN = 4;
+
+ private static final int NOTE_MODIFIED_DATE_COLUMN = 5;
+
+
+
+ // New note construct
+ private WorkingNote(Context context, long folderId) {
+ mContext = context;
+ mAlertDate = 0;
+ mModifiedDate = System.currentTimeMillis();
+ mFolderId = folderId;
+ mNote = new Note();
+ mNoteId = 0;
+ mIsDeleted = false;
+ mMode = 0;
+ mWidgetType = Notes.TYPE_WIDGET_INVALIDE;
+ }
+
+ // Existing note construct
+ private WorkingNote(Context context, long noteId, long folderId) {
+ mContext = context;
+ mNoteId = noteId;
+ mFolderId = folderId;
+ mIsDeleted = false;
+ mNote = new Note();
+ loadNote();
+ }
+
+ private void loadNote() {
+ Cursor cursor = mContext.getContentResolver().query(
+ ContentUris.withAppendedId(Notes.CONTENT_NOTE_URI, mNoteId), NOTE_PROJECTION, null,
+ null, null);
+
+ if (cursor != null) {
+ if (cursor.moveToFirst()) {
+ mFolderId = cursor.getLong(NOTE_PARENT_ID_COLUMN);
+ mBgColorId = cursor.getInt(NOTE_BG_COLOR_ID_COLUMN);
+ mWidgetId = cursor.getInt(NOTE_WIDGET_ID_COLUMN);
+ mWidgetType = cursor.getInt(NOTE_WIDGET_TYPE_COLUMN);
+ mAlertDate = cursor.getLong(NOTE_ALERTED_DATE_COLUMN);
+ mModifiedDate = cursor.getLong(NOTE_MODIFIED_DATE_COLUMN);
+
+ }
+ cursor.close();
+ } else {
+ Log.e(TAG, "No note with id:" + mNoteId);
+ throw new IllegalArgumentException("Unable to find note with id " + mNoteId);
+ }
+ loadNoteData();
+ }
+
+ private void loadNoteData() {
+ Cursor cursor = mContext.getContentResolver().query(Notes.CONTENT_DATA_URI, DATA_PROJECTION,
+ DataColumns.NOTE_ID + "=?", new String[] {
+ String.valueOf(mNoteId)
+ }, null);
+
+ if (cursor != null) {
+ if (cursor.moveToFirst()) {
+ do {
+ String type = cursor.getString(DATA_MIME_TYPE_COLUMN);
+ if (DataConstants.NOTE.equals(type)) {
+ mContent = cursor.getString(DATA_CONTENT_COLUMN);
+ mMode = cursor.getInt(DATA_MODE_COLUMN);
+ mNote.setTextDataId(cursor.getLong(DATA_ID_COLUMN));
+ } else if (DataConstants.CALL_NOTE.equals(type)) {
+ mNote.setCallDataId(cursor.getLong(DATA_ID_COLUMN));
+ } else {
+ Log.d(TAG, "Wrong note type with type:" + type);
+ }
+ } while (cursor.moveToNext());
+ }
+ cursor.close();
+ } else {
+ Log.e(TAG, "No data with id:" + mNoteId);
+ throw new IllegalArgumentException("Unable to find note's data with id " + mNoteId);
+ }
+ }
+
+ public static WorkingNote createEmptyNote(Context context, long folderId, int widgetId,
+ int widgetType, int defaultBgColorId) {
+ WorkingNote note = new WorkingNote(context, folderId);
+ note.setBgColorId(defaultBgColorId);
+ note.setWidgetId(widgetId);
+ note.setWidgetType(widgetType);
+ return note;
+ }
+
+ public static WorkingNote load(Context context, long id) {
+ return new WorkingNote(context, id, 0);
+ }
+
+ public synchronized boolean saveNote() {
+ if (isWorthSaving()) {
+ if (!existInDatabase()) {
+ if ((mNoteId = Note.getNewNoteId(mContext, mFolderId)) == 0) {
+ Log.e(TAG, "Create new note fail with id:" + mNoteId);
+ return false;
+ }
+ }
+
+ mNote.syncNote(mContext, mNoteId);
+
+ /**
+ * Update widget content if there exist any widget of this note
+ */
+ if (mWidgetId != AppWidgetManager.INVALID_APPWIDGET_ID
+ && mWidgetType != Notes.TYPE_WIDGET_INVALIDE
+ && mNoteSettingStatusListener != null) {
+ mNoteSettingStatusListener.onWidgetChanged();
+ }
+ return true;
+ } else {
+ return false;
+ }
+ }
+
+ public boolean existInDatabase() {
+ return mNoteId > 0;
+ }
+
+ private boolean isWorthSaving() {
+ if (mIsDeleted || (!existInDatabase() && TextUtils.isEmpty(mContent))
+ || (existInDatabase() && !mNote.isLocalModified())) {
+ return false;
+ } else {
+ return true;
+ }
+ }
+
+ public void setOnSettingStatusChangedListener(NoteSettingChangedListener l) {
+ mNoteSettingStatusListener = l;
+ }
+
+ public void setAlertDate(long date, boolean set) {
+ if (date != mAlertDate) {
+ mAlertDate = date;
+ mNote.setNoteValue(NoteColumns.ALERTED_DATE, String.valueOf(mAlertDate));
+ }
+ if (mNoteSettingStatusListener != null) {
+ mNoteSettingStatusListener.onClockAlertChanged(date, set);
+ }
+ }
+
+ public void markDeleted(boolean mark) {
+ mIsDeleted = mark;
+ if (mWidgetId != AppWidgetManager.INVALID_APPWIDGET_ID
+ && mWidgetType != Notes.TYPE_WIDGET_INVALIDE && mNoteSettingStatusListener != null) {
+ mNoteSettingStatusListener.onWidgetChanged();
+ }
+ }
+
+ public void setBgColorId(int id) {
+ if (id != mBgColorId) {
+ mBgColorId = id;
+ if (mNoteSettingStatusListener != null) {
+ mNoteSettingStatusListener.onBackgroundColorChanged();
+ }
+ mNote.setNoteValue(NoteColumns.BG_COLOR_ID, String.valueOf(id));
+ }
+ }
+
+ public void setCheckListMode(int mode, boolean listed) {
+ if (mMode != mode) {
+ if (mNoteSettingStatusListener != null && listed) {
+ mNoteSettingStatusListener.onCheckListModeChanged(mMode, mode);
+ }
+ mMode = mode;
+ mNote.setTextData(TextNote.MODE, String.valueOf(mMode));
+ }
+ }
+
+ public void setWidgetType(int type) {
+ if (type != mWidgetType) {
+ mWidgetType = type;
+ mNote.setNoteValue(NoteColumns.WIDGET_TYPE, String.valueOf(mWidgetType));
+ }
+ }
+
+ public void setWidgetId(int id) {
+ if (id != mWidgetId) {
+ mWidgetId = id;
+ mNote.setNoteValue(NoteColumns.WIDGET_ID, String.valueOf(mWidgetId));
+ }
+ }
+
+ public void setWorkingText(String text) {
+ if (!TextUtils.equals(mContent, text)) {
+ mContent = text;
+ mNote.setTextData(DataColumns.CONTENT, mContent);
+ }
+ }
+
+ public void convertToCallNote(String phoneNumber, long callDate) {
+ mNote.setCallData(CallNote.CALL_DATE, String.valueOf(callDate));
+ mNote.setCallData(CallNote.PHONE_NUMBER, phoneNumber);
+ mNote.setNoteValue(NoteColumns.PARENT_ID, String.valueOf(Notes.ID_CALL_RECORD_FOLDER));
+ }
+
+ public boolean hasClockAlert() {
+ return (mAlertDate > 0 ? true : false);
+ }
+
+ public String getContent() {
+ return mContent;
+ }
+
+ public long getAlertDate() {
+ return mAlertDate;
+ }
+
+ public long getModifiedDate() {
+ return mModifiedDate;
+ }
+
+ public int getBgColorResId() {
+ return NoteBgResources.getNoteBgResource(mBgColorId);
+ }
+
+ public int getBgColorId() {
+ return mBgColorId;
+ }
+
+ public int getTitleBgResId() {
+ return NoteBgResources.getNoteTitleBgResource(mBgColorId);
+ }
+
+ public int getCheckListMode() {
+ return mMode;
+ }
+
+ public long getNoteId() {
+ return mNoteId;
+ }
+
+ public long getFolderId() {
+ return mFolderId;
+ }
+
+ public int getWidgetId() {
+ return mWidgetId;
+ }
+
+ public int getWidgetType() {
+ return mWidgetType;
+ }
+ //mine 22
+ public boolean comparePassword(String passWord)
+ {
+ Cursor cursor = mContext.getContentResolver().query(
+ ContentUris.withAppendedId(Notes.CONTENT_NOTE_URI, mNoteId), new String[]{NoteColumns.PASSWORD}, null,
+ null, null);
+ int passWordIndex = cursor.getColumnIndexOrThrow(NoteColumns.PASSWORD);
+ cursor.moveToFirst();
+ String str = cursor.getString(passWordIndex);
+ cursor.close();
+ return str.equals(passWord);
+ }
+
+ public void setmPwd(String password,String hint)
+ {
+ mNote.setNoteValue(NoteColumns.PASSWORD, String.valueOf(password));
+ mNote.setNoteValue(NoteColumns.HINT, String.valueOf(hint));
+ }
+
+ public void delmPwd(){
+ mNote.setNoteValue(NoteColumns.PASSWORD, "");
+ mNote.setNoteValue(NoteColumns.HINT, "");
+ }
+ public interface NoteSettingChangedListener {
+ /**
+ * Called when the background color of current note has just changed
+ */
+ void onBackgroundColorChanged();
+
+ /**
+ * Called when user set clock
+ */
+ void onClockAlertChanged(long date, boolean set);
+
+ /**
+ * Call when user create note from widget
+ */
+ void onWidgetChanged();
+
+ /**
+ * Call when switch between check list mode and normal mode
+ * @param oldMode is previous mode before change
+ * @param newMode is new mode
+ */
+ void onCheckListModeChanged(int oldMode, int newMode);
+ }
+}
diff --git a/src/src/app/src/main/java/net/micode/notes/tool/BackupUtils.java b/src/src/app/src/main/java/net/micode/notes/tool/BackupUtils.java
new file mode 100644
index 0000000..05d3722
--- /dev/null
+++ b/src/src/app/src/main/java/net/micode/notes/tool/BackupUtils.java
@@ -0,0 +1,357 @@
+/*
+ * Copyright (c) 2010-2011, The MiCode Open Source Community (www.micode.net)
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+
+package net.micode.notes.tool;
+
+import android.annotation.TargetApi;
+import android.content.Context;
+import android.database.Cursor;
+import android.os.Build;
+import android.os.Environment;
+import android.text.TextUtils;
+import android.text.format.DateFormat;
+import android.util.Log;
+
+import net.micode.notes.R;
+import net.micode.notes.data.Notes;
+import net.micode.notes.data.Notes.DataColumns;
+import net.micode.notes.data.Notes.DataConstants;
+import net.micode.notes.data.Notes.NoteColumns;
+
+import java.io.File;
+import java.io.FileNotFoundException;
+import java.io.FileOutputStream;
+import java.io.IOException;
+import java.io.PrintStream;
+
+
+public class BackupUtils {
+ private static final String TAG = "BackupUtils";
+ // Singleton stuff
+ private static BackupUtils sInstance;
+
+ public static synchronized BackupUtils getInstance(Context context) {
+ if (sInstance == null) {
+ sInstance = new BackupUtils(context);
+ }
+ return sInstance;
+ }
+
+ /**
+ * Following states are signs to represents backup or restore
+ * status
+ */
+ // Currently, the sdcard is not mounted
+ public static final int STATE_SD_CARD_UNMOUONTED = 0;
+ // The backup file not exist
+ public static final int STATE_BACKUP_FILE_NOT_EXIST = 1;
+ // The data is not well formated, may be changed by other programs
+ public static final int STATE_DATA_DESTROIED = 2;
+ // Some run-time exception which causes restore or backup fails
+ public static final int STATE_SYSTEM_ERROR = 3;
+ // Backup or restore success
+ public static final int STATE_SUCCESS = 4;
+
+ private TextExport mTextExport;
+
+ private BackupUtils(Context context) {
+ mTextExport = new TextExport(context);
+ }
+
+ private static boolean externalStorageAvailable() {
+ return Environment.MEDIA_MOUNTED.equals(Environment.getExternalStorageState());
+ }
+
+ public int exportToText() {
+ return mTextExport.exportToText();
+ }
+
+ public String getExportedTextFileName() {
+ return mTextExport.mFileName;
+ }
+
+ public String getExportedTextFileDir() {
+ return mTextExport.mFileDirectory;
+ }
+
+ private static class TextExport {
+ private static final String[] NOTE_PROJECTION = {
+ NoteColumns.ID,
+ NoteColumns.MODIFIED_DATE,
+ NoteColumns.SNIPPET,
+ NoteColumns.TYPE
+ };
+
+ private static final int NOTE_COLUMN_ID = 0;
+
+ private static final int NOTE_COLUMN_MODIFIED_DATE = 1;
+
+ private static final int NOTE_COLUMN_SNIPPET = 2;
+
+ private static final String[] DATA_PROJECTION = {
+ DataColumns.CONTENT,
+ DataColumns.MIME_TYPE,
+ DataColumns.DATA1,
+ DataColumns.DATA2,
+ DataColumns.DATA3,
+ DataColumns.DATA4,
+ };
+
+ private static final int DATA_COLUMN_CONTENT = 0;
+
+ private static final int DATA_COLUMN_MIME_TYPE = 1;
+
+ private static final int DATA_COLUMN_CALL_DATE = 2;
+
+ private static final int DATA_COLUMN_PHONE_NUMBER = 4;
+
+ private final String [] TEXT_FORMAT;
+ private static final int FORMAT_FOLDER_NAME = 0;
+ private static final int FORMAT_NOTE_DATE = 1;
+ private static final int FORMAT_NOTE_CONTENT = 2;
+
+ private Context mContext;
+ private String mFileName;
+ private String mFileDirectory;
+
+ public TextExport(Context context) {
+ TEXT_FORMAT = context.getResources().getStringArray(R.array.format_for_exported_note);
+ mContext = context;
+ mFileName = "";
+ mFileDirectory = "";
+ }
+
+ private String getFormat(int id) {
+ return TEXT_FORMAT[id];
+ }
+
+ /**
+ * Export the folder identified by folder id to text
+ */
+ private void exportFolderToText(String folderId, PrintStream ps) {
+ // Query notes belong to this folder
+ Cursor notesCursor = mContext.getContentResolver().query(Notes.CONTENT_NOTE_URI,
+ NOTE_PROJECTION, NoteColumns.PARENT_ID + "=?", new String[] {
+ folderId
+ }, null);
+
+ if (notesCursor != null) {
+ if (notesCursor.moveToFirst()) {
+ do {
+ // Print note's last modified date
+ ps.println(String.format(getFormat(FORMAT_NOTE_DATE), DateFormat.format(
+ mContext.getString(R.string.format_datetime_mdhm),
+ notesCursor.getLong(NOTE_COLUMN_MODIFIED_DATE))));
+ // Query data belong to this note
+ String noteId = notesCursor.getString(NOTE_COLUMN_ID);
+ exportNoteToText(noteId, ps);
+ } while (notesCursor.moveToNext());
+ }
+ notesCursor.close();
+ }
+ }
+
+ /**
+ * Export note identified by id to a print stream
+ */
+ private void exportNoteToText(String noteId, PrintStream ps) {
+ Cursor dataCursor = mContext.getContentResolver().query(Notes.CONTENT_DATA_URI,
+ DATA_PROJECTION, DataColumns.NOTE_ID + "=?", new String[] {
+ noteId
+ }, null);
+
+ if (dataCursor != null) {
+ if (dataCursor.moveToFirst()) {
+ do {
+ String mimeType = dataCursor.getString(DATA_COLUMN_MIME_TYPE);
+ if (DataConstants.CALL_NOTE.equals(mimeType)) {
+ // Print phone number
+ String phoneNumber = dataCursor.getString(DATA_COLUMN_PHONE_NUMBER);
+ long callDate = dataCursor.getLong(DATA_COLUMN_CALL_DATE);
+ String location = dataCursor.getString(DATA_COLUMN_CONTENT);
+
+ if (!TextUtils.isEmpty(phoneNumber)) {
+ ps.println(String.format(getFormat(FORMAT_NOTE_CONTENT),
+ phoneNumber));
+ }
+ // Print call date
+ ps.println(String.format(getFormat(FORMAT_NOTE_CONTENT), DateFormat
+ .format(mContext.getString(R.string.format_datetime_mdhm),
+ callDate)));
+ // Print call attachment location
+ if (!TextUtils.isEmpty(location)) {
+ ps.println(String.format(getFormat(FORMAT_NOTE_CONTENT),
+ location));
+ }
+ } else if (DataConstants.NOTE.equals(mimeType)) {
+ String content = dataCursor.getString(DATA_COLUMN_CONTENT);
+ if (!TextUtils.isEmpty(content)) {
+ ps.println(String.format(getFormat(FORMAT_NOTE_CONTENT),
+ content));
+ }
+ }
+ } while (dataCursor.moveToNext());
+ }
+ dataCursor.close();
+ }
+ // print a line separator between note
+ try {
+ ps.write(new byte[] {
+ Character.LINE_SEPARATOR, Character.LETTER_NUMBER
+ });
+ } catch (IOException e) {
+ Log.e(TAG, e.toString());
+ }
+ }
+
+ /**
+ * Note will be exported as text which is user readable
+ */
+ public int exportToText() {
+ if (!externalStorageAvailable()) {
+ Log.d(TAG, "Media was not mounted");
+ return STATE_SD_CARD_UNMOUONTED;
+ }
+
+ PrintStream ps = getExportToTextPrintStream();
+ if (ps == null) {
+ Log.e(TAG, "get print stream error");
+ return STATE_SYSTEM_ERROR;
+ }
+ // First export folder and its notes
+ Cursor folderCursor = mContext.getContentResolver().query(
+ Notes.CONTENT_NOTE_URI,
+ NOTE_PROJECTION,
+ "(" + NoteColumns.TYPE + "=" + Notes.TYPE_FOLDER + " AND "
+ + NoteColumns.PARENT_ID + "<>" + Notes.ID_TRASH_FOLER + ") OR "
+ + NoteColumns.ID + "=" + Notes.ID_CALL_RECORD_FOLDER, null, null);
+
+ if (folderCursor != null) {
+ if (folderCursor.moveToFirst()) {
+ do {
+ // Print folder's name
+ String folderName = "";
+ if(folderCursor.getLong(NOTE_COLUMN_ID) == Notes.ID_CALL_RECORD_FOLDER) {
+ folderName = mContext.getString(R.string.call_record_folder_name);
+ } else {
+ folderName = folderCursor.getString(NOTE_COLUMN_SNIPPET);
+ }
+ if (!TextUtils.isEmpty(folderName)) {
+ ps.println(String.format(getFormat(FORMAT_FOLDER_NAME), folderName));
+ }
+ String folderId = folderCursor.getString(NOTE_COLUMN_ID);
+ exportFolderToText(folderId, ps);
+ } while (folderCursor.moveToNext());
+ }
+ folderCursor.close();
+ }
+
+ // Export notes in root's folder
+ Cursor noteCursor = mContext.getContentResolver().query(
+ Notes.CONTENT_NOTE_URI,
+ NOTE_PROJECTION,
+ NoteColumns.TYPE + "=" + +Notes.TYPE_NOTE + " AND " + NoteColumns.PARENT_ID
+ + "=0", null, null);
+
+ if (noteCursor != null) {
+ if (noteCursor.moveToFirst()) {
+ do {
+ ps.println(String.format(getFormat(FORMAT_NOTE_DATE), DateFormat.format(
+ mContext.getString(R.string.format_datetime_mdhm),
+ noteCursor.getLong(NOTE_COLUMN_MODIFIED_DATE))));
+ // Query data belong to this note
+ String noteId = noteCursor.getString(NOTE_COLUMN_ID);
+ exportNoteToText(noteId, ps);
+ } while (noteCursor.moveToNext());
+ }
+ noteCursor.close();
+ }
+ ps.close();
+
+ return STATE_SUCCESS;
+ }
+
+ /**
+ * Get a print stream pointed to the file {@generateExportedTextFile}
+ */
+ @TargetApi(Build.VERSION_CODES.KITKAT)
+ private PrintStream getExportToTextPrintStream() {
+ File file = generateFileMountedOnSDcard(mContext, R.string.file_path,
+ R.string.file_name_txt_format);
+ if (file == null) {
+ Log.e(TAG, "create file to exported failed");
+ return null;
+ }
+ mFileName = file.getName();
+ mFileDirectory = mContext.getString(R.string.file_path);
+ PrintStream ps = null;
+
+ try(FileOutputStream fos = new FileOutputStream(file);) {
+ ps = new PrintStream(fos);
+ } catch (FileNotFoundException e) {
+ Log.e(TAG, "getExportToTextPrintStream: " + e.toString() );
+ return null;
+ } catch (NullPointerException e) {
+ Log.e(TAG, "getExportToTextPrintStream: " + e.toString() );
+ return null;
+ } catch (IOException e) {
+ Log.e(TAG, "getExportToTextPrintStream: " + e.toString() );
+ return null;
+ }
+
+ return ps;
+ }
+ }
+
+ /**
+ * Generate the text file to store imported data
+ */
+ private static File generateFileMountedOnSDcard(Context context, int filePathResId, int fileNameFormatResId) {
+ StringBuilder sb = new StringBuilder();
+ sb.append(Environment.getExternalStorageDirectory());
+ sb.append(context.getString(filePathResId));
+ File filedir = new File(sb.toString());
+ sb.append(context.getString(
+ fileNameFormatResId,
+ DateFormat.format(context.getString(R.string.format_date_ymd),
+ System.currentTimeMillis())));
+ File file = new File(sb.toString());
+
+ try {
+ if (!filedir.exists()) {
+ filedir.mkdir();
+ }
+ if (!file.exists()) {
+ boolean Bool = file.createNewFile();
+ if(Bool == false)
+ Log.e(TAG, "generateFileMountedOnSDcard: createNewFile false");
+ else
+ Log.e(TAG, "generateFileMountedOnSDcard: createNewFile true");
+ }
+ return file;
+ } catch (SecurityException e) {
+ //e.printStackTrace();
+ Log.e(TAG, "generateFileMountedOnSDcard: "+ e.toString() );
+ } catch (IOException e) {
+ //e.printStackTrace();
+ Log.e(TAG, "generateFileMountedOnSDcard: " + e.toString() );
+ }
+
+ return null;
+ }
+}
+
+
diff --git a/src/src/app/src/main/java/net/micode/notes/tool/DataUtils.java b/src/src/app/src/main/java/net/micode/notes/tool/DataUtils.java
new file mode 100644
index 0000000..2a14982
--- /dev/null
+++ b/src/src/app/src/main/java/net/micode/notes/tool/DataUtils.java
@@ -0,0 +1,295 @@
+/*
+ * Copyright (c) 2010-2011, The MiCode Open Source Community (www.micode.net)
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+
+package net.micode.notes.tool;
+
+import android.content.ContentProviderOperation;
+import android.content.ContentProviderResult;
+import android.content.ContentResolver;
+import android.content.ContentUris;
+import android.content.ContentValues;
+import android.content.OperationApplicationException;
+import android.database.Cursor;
+import android.os.RemoteException;
+import android.util.Log;
+
+import net.micode.notes.data.Notes;
+import net.micode.notes.data.Notes.CallNote;
+import net.micode.notes.data.Notes.NoteColumns;
+import net.micode.notes.ui.NotesListAdapter.AppWidgetAttribute;
+
+import java.util.ArrayList;
+import java.util.HashSet;
+
+
+public class DataUtils {
+ public static final String TAG = "DataUtils";
+ public static boolean batchDeleteNotes(ContentResolver resolver, HashSet ids) {
+ if (ids == null) {
+ Log.d(TAG, "the ids is null");
+ return true;
+ }
+ if (ids.size() == 0) {
+ Log.d(TAG, "no id is in the hashset");
+ return true;
+ }
+
+ ArrayList operationList = new ArrayList();
+ for (long id : ids) {
+ if(id == Notes.ID_ROOT_FOLDER) {
+ Log.e(TAG, "Don't delete system folder root");
+ continue;
+ }
+ ContentProviderOperation.Builder builder = ContentProviderOperation
+ .newDelete(ContentUris.withAppendedId(Notes.CONTENT_NOTE_URI, id));
+ operationList.add(builder.build());
+ }
+ try {
+ ContentProviderResult[] results = resolver.applyBatch(Notes.AUTHORITY, operationList);
+ if (results == null || results.length == 0 || results[0] == null) {
+ Log.d(TAG, "delete notes failed, ids:" + ids.toString());
+ return false;
+ }
+ return true;
+ } catch (RemoteException e) {
+ Log.e(TAG, String.format("%s: %s", e.toString(), e.getMessage()));
+ } catch (OperationApplicationException e) {
+ Log.e(TAG, String.format("%s: %s", e.toString(), e.getMessage()));
+ }
+ return false;
+ }
+
+ public static void moveNoteToFoler(ContentResolver resolver, long id, long srcFolderId, long desFolderId) {
+ ContentValues values = new ContentValues();
+ values.put(NoteColumns.PARENT_ID, desFolderId);
+ values.put(NoteColumns.ORIGIN_PARENT_ID, srcFolderId);
+ values.put(NoteColumns.LOCAL_MODIFIED, 1);
+ resolver.update(ContentUris.withAppendedId(Notes.CONTENT_NOTE_URI, id), values, null, null);
+ }
+
+ public static boolean batchMoveToFolder(ContentResolver resolver, HashSet ids,
+ long folderId) {
+ if (ids == null) {
+ Log.d(TAG, "the ids is null");
+ return true;
+ }
+
+ ArrayList operationList = new ArrayList();
+ for (long id : ids) {
+ ContentProviderOperation.Builder builder = ContentProviderOperation
+ .newUpdate(ContentUris.withAppendedId(Notes.CONTENT_NOTE_URI, id));
+ builder.withValue(NoteColumns.PARENT_ID, folderId);
+ builder.withValue(NoteColumns.LOCAL_MODIFIED, 1);
+ operationList.add(builder.build());
+ }
+
+ try {
+ ContentProviderResult[] results = resolver.applyBatch(Notes.AUTHORITY, operationList);
+ if (results == null || results.length == 0 || results[0] == null) {
+ Log.d(TAG, "delete notes failed, ids:" + ids.toString());
+ return false;
+ }
+ return true;
+ } catch (RemoteException e) {
+ Log.e(TAG, String.format("%s: %s", e.toString(), e.getMessage()));
+ } catch (OperationApplicationException e) {
+ Log.e(TAG, String.format("%s: %s", e.toString(), e.getMessage()));
+ }
+ return false;
+ }
+
+ /**
+ * Get the all folder count except system folders {@link Notes#TYPE_SYSTEM}}
+ */
+ public static int getUserFolderCount(ContentResolver resolver) {
+ Cursor cursor =resolver.query(Notes.CONTENT_NOTE_URI,
+ new String[] { "COUNT(*)" },
+ NoteColumns.TYPE + "=? AND " + NoteColumns.PARENT_ID + "<>?",
+ new String[] { String.valueOf(Notes.TYPE_FOLDER), String.valueOf(Notes.ID_TRASH_FOLER)},
+ null);
+
+ int count = 0;
+ if(cursor != null) {
+ if(cursor.moveToFirst()) {
+ try {
+ count = cursor.getInt(0);
+ } catch (IndexOutOfBoundsException e) {
+ Log.e(TAG, "get folder count failed:" + e.toString());
+ } finally {
+ cursor.close();
+ }
+ }
+ }
+ return count;
+ }
+
+ public static boolean visibleInNoteDatabase(ContentResolver resolver, long noteId, int type) {
+ Cursor cursor = resolver.query(ContentUris.withAppendedId(Notes.CONTENT_NOTE_URI, noteId),
+ null,
+ NoteColumns.TYPE + "=? AND " + NoteColumns.PARENT_ID + "<>" + Notes.ID_TRASH_FOLER,
+ new String [] {String.valueOf(type)},
+ null);
+
+ boolean exist = false;
+ if (cursor != null) {
+ if (cursor.getCount() > 0) {
+ exist = true;
+ }
+ cursor.close();
+ }
+ return exist;
+ }
+
+ public static boolean existInNoteDatabase(ContentResolver resolver, long noteId) {
+ Cursor cursor = resolver.query(ContentUris.withAppendedId(Notes.CONTENT_NOTE_URI, noteId),
+ null, null, null, null);
+
+ boolean exist = false;
+ if (cursor != null) {
+ if (cursor.getCount() > 0) {
+ exist = true;
+ }
+ cursor.close();
+ }
+ return exist;
+ }
+
+ public static boolean existInDataDatabase(ContentResolver resolver, long dataId) {
+ Cursor cursor = resolver.query(ContentUris.withAppendedId(Notes.CONTENT_DATA_URI, dataId),
+ null, null, null, null);
+
+ boolean exist = false;
+ if (cursor != null) {
+ if (cursor.getCount() > 0) {
+ exist = true;
+ }
+ cursor.close();
+ }
+ return exist;
+ }
+
+ public static boolean checkVisibleFolderName(ContentResolver resolver, String name) {
+ Cursor cursor = resolver.query(Notes.CONTENT_NOTE_URI, null,
+ NoteColumns.TYPE + "=" + Notes.TYPE_FOLDER +
+ " AND " + NoteColumns.PARENT_ID + "<>" + Notes.ID_TRASH_FOLER +
+ " AND " + NoteColumns.SNIPPET + "=?",
+ new String[] { name }, null);
+ boolean exist = false;
+ if(cursor != null) {
+ if(cursor.getCount() > 0) {
+ exist = true;
+ }
+ cursor.close();
+ }
+ return exist;
+ }
+
+ public static HashSet getFolderNoteWidget(ContentResolver resolver, long folderId) {
+ Cursor c = resolver.query(Notes.CONTENT_NOTE_URI,
+ new String[] { NoteColumns.WIDGET_ID, NoteColumns.WIDGET_TYPE },
+ NoteColumns.PARENT_ID + "=?",
+ new String[] { String.valueOf(folderId) },
+ null);
+
+ HashSet set = null;
+ if (c != null) {
+ if (c.moveToFirst()) {
+ set = new HashSet();
+ do {
+ try {
+ AppWidgetAttribute widget = new AppWidgetAttribute();
+ widget.widgetId = c.getInt(0);
+ widget.widgetType = c.getInt(1);
+ set.add(widget);
+ } catch (IndexOutOfBoundsException e) {
+ Log.e(TAG, e.toString());
+ }
+ } while (c.moveToNext());
+ }
+ c.close();
+ }
+ return set;
+ }
+
+ public static String getCallNumberByNoteId(ContentResolver resolver, long noteId) {
+ Cursor cursor = resolver.query(Notes.CONTENT_DATA_URI,
+ new String [] { CallNote.PHONE_NUMBER },
+ CallNote.NOTE_ID + "=? AND " + CallNote.MIME_TYPE + "=?",
+ new String [] { String.valueOf(noteId), CallNote.CONTENT_ITEM_TYPE },
+ null);
+
+ if (cursor != null && cursor.moveToFirst()) {
+ try {
+ return cursor.getString(0);
+ } catch (IndexOutOfBoundsException e) {
+ Log.e(TAG, "Get call number fails " + e.toString());
+ } finally {
+ cursor.close();
+ }
+ }
+ return "";
+ }
+
+ public static long getNoteIdByPhoneNumberAndCallDate(ContentResolver resolver, String phoneNumber, long callDate) {
+ Cursor cursor = resolver.query(Notes.CONTENT_DATA_URI,
+ new String [] { CallNote.NOTE_ID },
+ CallNote.CALL_DATE + "=? AND " + CallNote.MIME_TYPE + "=? AND PHONE_NUMBERS_EQUAL("
+ + CallNote.PHONE_NUMBER + ",?)",
+ new String [] { String.valueOf(callDate), CallNote.CONTENT_ITEM_TYPE, phoneNumber },
+ null);
+
+ if (cursor != null) {
+ if (cursor.moveToFirst()) {
+ try {
+ return cursor.getLong(0);
+ } catch (IndexOutOfBoundsException e) {
+ Log.e(TAG, "Get call note id fails " + e.toString());
+ }
+ }
+ cursor.close();
+ }
+ return 0;
+ }
+
+ public static String getSnippetById(ContentResolver resolver, long noteId) {
+ Cursor cursor = resolver.query(Notes.CONTENT_NOTE_URI,
+ new String [] { NoteColumns.SNIPPET },
+ NoteColumns.ID + "=?",
+ new String [] { String.valueOf(noteId)},
+ null);
+
+ if (cursor != null) {
+ String snippet = "";
+ if (cursor.moveToFirst()) {
+ snippet = cursor.getString(0);
+ }
+ cursor.close();
+ return snippet;
+ }
+ throw new IllegalArgumentException("Note is not found with id: " + noteId);
+ }
+
+ public static String getFormattedSnippet(String snippet) {
+ if (snippet != null) {
+ snippet = snippet.trim();
+ int index = snippet.indexOf('\n');
+ if (index != -1) {
+ snippet = snippet.substring(0, index);
+ }
+ }
+ return snippet;
+ }
+}
diff --git a/src/src/app/src/main/java/net/micode/notes/tool/GTaskStringUtils.java b/src/src/app/src/main/java/net/micode/notes/tool/GTaskStringUtils.java
new file mode 100644
index 0000000..666b729
--- /dev/null
+++ b/src/src/app/src/main/java/net/micode/notes/tool/GTaskStringUtils.java
@@ -0,0 +1,113 @@
+/*
+ * Copyright (c) 2010-2011, The MiCode Open Source Community (www.micode.net)
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+
+package net.micode.notes.tool;
+
+public class GTaskStringUtils {
+
+ public final static String GTASK_JSON_ACTION_ID = "action_id";
+
+ public final static String GTASK_JSON_ACTION_LIST = "action_list";
+
+ public final static String GTASK_JSON_ACTION_TYPE = "action_type";
+
+ public final static String GTASK_JSON_ACTION_TYPE_CREATE = "create";
+
+ public final static String GTASK_JSON_ACTION_TYPE_GETALL = "get_all";
+
+ public final static String GTASK_JSON_ACTION_TYPE_MOVE = "move";
+
+ public final static String GTASK_JSON_ACTION_TYPE_UPDATE = "update";
+
+ public final static String GTASK_JSON_CREATOR_ID = "creator_id";
+
+ public final static String GTASK_JSON_CHILD_ENTITY = "child_entity";
+
+ public final static String GTASK_JSON_CLIENT_VERSION = "client_version";
+
+ public final static String GTASK_JSON_COMPLETED = "completed";
+
+ public final static String GTASK_JSON_CURRENT_LIST_ID = "current_list_id";
+
+ public final static String GTASK_JSON_DEFAULT_LIST_ID = "default_list_id";
+
+ public final static String GTASK_JSON_DELETED = "deleted";
+
+ public final static String GTASK_JSON_DEST_LIST = "dest_list";
+
+ public final static String GTASK_JSON_DEST_PARENT = "dest_parent";
+
+ public final static String GTASK_JSON_DEST_PARENT_TYPE = "dest_parent_type";
+
+ public final static String GTASK_JSON_ENTITY_DELTA = "entity_delta";
+
+ public final static String GTASK_JSON_ENTITY_TYPE = "entity_type";
+
+ public final static String GTASK_JSON_GET_DELETED = "get_deleted";
+
+ public final static String GTASK_JSON_ID = "id";
+
+ public final static String GTASK_JSON_INDEX = "index";
+
+ public final static String GTASK_JSON_LAST_MODIFIED = "last_modified";
+
+ public final static String GTASK_JSON_LATEST_SYNC_POINT = "latest_sync_point";
+
+ public final static String GTASK_JSON_LIST_ID = "list_id";
+
+ public final static String GTASK_JSON_LISTS = "lists";
+
+ public final static String GTASK_JSON_NAME = "name";
+
+ public final static String GTASK_JSON_NEW_ID = "new_id";
+
+ public final static String GTASK_JSON_NOTES = "notes";
+
+ public final static String GTASK_JSON_PARENT_ID = "parent_id";
+
+ public final static String GTASK_JSON_PRIOR_SIBLING_ID = "prior_sibling_id";
+
+ public final static String GTASK_JSON_RESULTS = "results";
+
+ public final static String GTASK_JSON_SOURCE_LIST = "source_list";
+
+ public final static String GTASK_JSON_TASKS = "tasks";
+
+ public final static String GTASK_JSON_TYPE = "type";
+
+ public final static String GTASK_JSON_TYPE_GROUP = "GROUP";
+
+ public final static String GTASK_JSON_TYPE_TASK = "TASK";
+
+ public final static String GTASK_JSON_USER = "user";
+
+ public final static String MIUI_FOLDER_PREFFIX = "[MIUI_Notes]";
+
+ public final static String FOLDER_DEFAULT = "Default";
+
+ public final static String FOLDER_CALL_NOTE = "Call_Note";
+
+ public final static String FOLDER_META = "METADATA";
+
+ public final static String META_HEAD_GTASK_ID = "meta_gid";
+
+ public final static String META_HEAD_NOTE = "meta_note";
+
+ public final static String META_HEAD_DATA = "meta_data";
+
+ public final static String META_NOTE_NAME = "[META INFO] DON'T UPDATE AND DELETE";
+
+}
diff --git a/src/src/app/src/main/java/net/micode/notes/tool/ImageUtils.java b/src/src/app/src/main/java/net/micode/notes/tool/ImageUtils.java
new file mode 100644
index 0000000..a2d7463
--- /dev/null
+++ b/src/src/app/src/main/java/net/micode/notes/tool/ImageUtils.java
@@ -0,0 +1,359 @@
+package net.micode.notes.tool;
+
+import android.content.ContentResolver;
+import android.content.Context;
+import android.content.Intent;
+import android.graphics.Bitmap;
+import android.graphics.BitmapFactory;
+import android.graphics.Matrix;
+import android.net.Uri;
+import android.util.Base64;
+import android.util.Log;
+
+import java.io.ByteArrayInputStream;
+import java.io.ByteArrayOutputStream;
+import java.io.File;
+import java.io.InputStream;
+//mine 357
+/**
+ * Created by sendtion on 2016/5/25.
+ */
+public class ImageUtils {
+ /**
+ * 图片压缩处理,size参数为压缩比,比如size为2,则压缩为1/4
+ **/
+ public static Bitmap compressBitmap(String path, byte[] data, Context context, Uri uri, int size, boolean width) {
+ BitmapFactory.Options options = null;
+ if (size > 0) {
+ BitmapFactory.Options info = new BitmapFactory.Options();
+ /**如果设置true的时候,decode时候Bitmap返回的为数据将空*/
+ info.inJustDecodeBounds = false;
+ decodeBitmap(path, data, context, uri, info);
+ int dim = info.outWidth;
+ if (!width) dim = Math.max(dim, info.outHeight);
+ options = new BitmapFactory.Options();
+ /**把图片宽高读取放在Options里*/
+ options.inSampleSize = size;
+ }
+ Bitmap bm = null;
+ try {
+ bm = decodeBitmap(path, data, context, uri, options);
+ } catch (Exception e) {
+ e.printStackTrace();
+ }
+ return bm;
+ }
+
+
+ /**
+ * 把byte数据解析成图片
+ */
+ private static Bitmap decodeBitmap(String path, byte[] data, Context context, Uri uri, BitmapFactory.Options options) {
+ Bitmap result = null;
+ if (path != null) {
+ result = BitmapFactory.decodeFile(path, options);
+ } else if (data != null) {
+ result = BitmapFactory.decodeByteArray(data, 0, data.length, options);
+ } else if (uri != null) {
+ ContentResolver cr = context.getContentResolver();
+ InputStream inputStream = null;
+ try {
+ inputStream = cr.openInputStream(uri);
+ result = BitmapFactory.decodeStream(inputStream, null, options);
+ inputStream.close();
+ } catch (Exception e) {
+ e.printStackTrace();
+ }
+ }
+ return result;
+ }
+
+
+ /**
+ * 把bitmap转换成String
+ *
+ * @param filePath
+ * @return
+ */
+ public static String bitmapToString(String filePath) {
+
+ Bitmap bm = getSmallBitmap(filePath, 480, 800);
+
+ ByteArrayOutputStream baos = new ByteArrayOutputStream();
+ try {
+ bm.compress(Bitmap.CompressFormat.JPEG, 40, baos);
+ }catch (NullPointerException e){
+ e.printStackTrace();
+ }
+ byte[] b = baos.toByteArray();
+
+ return Base64.encodeToString(b, Base64.DEFAULT);
+
+ }
+
+ /**
+ * 计算图片的缩放值
+ *
+ * @param options
+ * @param reqWidth
+ * @param reqHeight
+ * @return
+ */
+ public static int calculateInSampleSize(BitmapFactory.Options options,
+ int reqWidth, int reqHeight) {
+ // Raw height and width of image
+ final int height = options.outHeight;
+ final int width = options.outWidth;
+ int inSampleSize = 1;
+
+ if (height > reqHeight || width > reqWidth) {
+
+ // Calculate ratios of height and width to requested height and
+ // width
+ final int heightRatio = Math.round((float) height / (float) reqHeight);
+ final int widthRatio = Math.round((float) width / (float) reqWidth);
+
+ // Choose the smallest ratio as inSampleSize value, this will
+ // guarantee
+ // a final image with both dimensions larger than or equal to the
+ // requested height and width.
+ inSampleSize = heightRatio < widthRatio ? heightRatio : widthRatio;
+ }
+
+ return inSampleSize;
+ }
+
+ /**
+ * 根据路径获得图片并压缩返回bitmap用于显示
+ *
+ * @return
+ */
+ public static Bitmap getSmallBitmap(String filePath, int newWidth, int newHeight) {
+ final BitmapFactory.Options options = new BitmapFactory.Options();
+ options.inJustDecodeBounds = true;
+ BitmapFactory.decodeFile(filePath, options);
+
+ // Calculate inSampleSize
+ options.inSampleSize = calculateInSampleSize(options, newWidth, newHeight);
+
+ // Decode bitmap with inSampleSize set
+ options.inJustDecodeBounds = false;
+
+ Bitmap bitmap = BitmapFactory.decodeFile(filePath, options);
+ Bitmap newBitmap = compressImage(bitmap, 600);
+ if (bitmap != null){
+ bitmap.recycle();
+ }
+ return newBitmap;
+ }
+
+ /**
+ * 根据路径删除图片
+ *
+ * @param path
+ */
+ public static void deleteTempFile(String path) {
+ File file = new File(path);
+ if (file.exists()) {
+ file.delete();
+ }
+ }
+
+ /**
+ * 添加到图库
+ */
+ public static void galleryAddPic(Context context, String path) {
+ Intent mediaScanIntent = new Intent(
+ Intent.ACTION_MEDIA_SCANNER_SCAN_FILE);
+ File f = new File(path);
+ Uri contentUri = Uri.fromFile(f);
+ mediaScanIntent.setData(contentUri);
+ context.sendBroadcast(mediaScanIntent);
+ }
+
+ //使用Bitmap加Matrix来缩放
+ public static Bitmap resizeImage(Bitmap bitmapOrg, int newWidth, int newHeight)
+ {
+// Bitmap bitmapOrg = BitmapFactory.decodeFile(imagePath);
+ // 获取这个图片的宽和高
+ int width = bitmapOrg.getWidth();
+ int height = bitmapOrg.getHeight();
+ //如果宽度为0 保持原图
+ if(newWidth == 0){
+ newWidth = width;
+ newHeight = height;
+ }
+ // 创建操作图片用的matrix对象
+ Matrix matrix = new Matrix();
+ // 计算宽高缩放率
+ float scaleWidth = (float)newWidth / width;
+ float scaleHeight = (float)newHeight / height;
+ // 缩放图片动作
+ matrix.postScale(scaleWidth, scaleHeight);
+ Bitmap resizedBitmap = Bitmap.createBitmap(bitmapOrg, 0, 0, newWidth,
+ newHeight, matrix, true);
+ //Log.e("###newWidth=", resizedBitmap.getWidth()+"");
+ //Log.e("###newHeight=", resizedBitmap.getHeight()+"");
+ resizedBitmap = compressImage(resizedBitmap, 100);//质量压缩
+ return resizedBitmap;
+ }
+
+ //使用BitmapFactory.Options的inSampleSize参数来缩放
+ public static Bitmap resizeImage2(String path, int width, int height)
+ {
+ BitmapFactory.Options options = new BitmapFactory.Options();
+ options.inJustDecodeBounds = true;//不加载bitmap到内存中
+ BitmapFactory.decodeFile(path,options);
+ int outWidth = options.outWidth;
+ int outHeight = options.outHeight;
+ options.inDither = false;
+ options.inPreferredConfig = Bitmap.Config.ARGB_8888;
+ options.inSampleSize = 1;
+
+ if (outWidth != 0 && outHeight != 0 && width != 0 && height != 0)
+ {
+ int sampleSize=(outWidth/width+outHeight/height)/2;
+ Log.d("###", "sampleSize = " + sampleSize);
+ options.inSampleSize = sampleSize;
+ }
+
+ options.inJustDecodeBounds = false;
+ return BitmapFactory.decodeFile(path, options);
+ }
+
+ /**
+ * 通过像素压缩图片,将修改图片宽高,适合获得缩略图,Used to get thumbnail
+ * @param srcPath
+ * @return
+ */
+ public static Bitmap compressBitmapByPath(String srcPath, float pixelW, float pixelH) {
+ BitmapFactory.Options newOpts = new BitmapFactory.Options();
+ //开始读入图片,此时把options.inJustDecodeBounds 设回true了
+ newOpts.inJustDecodeBounds = true;
+ newOpts.inPreferredConfig = Bitmap.Config.RGB_565;
+ Bitmap bitmap = BitmapFactory.decodeFile(srcPath,newOpts);//此时返回bm为空
+
+ newOpts.inJustDecodeBounds = false;
+ int w = newOpts.outWidth;
+ int h = newOpts.outHeight;
+ //现在主流手机比较多是800*480分辨率,所以高和宽我们设置为
+ float hh = pixelH;//这里设置高度为800f
+ float ww = pixelW;//这里设置宽度为480f
+ //缩放比。由于是固定比例缩放,只用高或者宽其中一个数据进行计算即可
+ int be = 1;//be=1表示不缩放
+ if (w > h && w > ww) {//如果宽度大的话根据宽度固定大小缩放
+ be = (int) (newOpts.outWidth / ww);
+ } else if (w < h && h > hh) {//如果高度高的话根据宽度固定大小缩放
+ be = (int) (newOpts.outHeight / hh);
+ }
+ if (be <= 0)
+ be = 1;
+ newOpts.inSampleSize = be;//设置缩放比例
+ //重新读入图片,注意此时已经把options.inJustDecodeBounds 设回false了
+ bitmap = BitmapFactory.decodeFile(srcPath, newOpts);
+ // return compress(bitmap, maxSize); // 这里再进行质量压缩的意义不大,反而耗资源,删除
+ return bitmap;
+ }
+
+ /**
+ * 通过大小压缩,将修改图片宽高,适合获得缩略图,Used to get thumbnail
+ * @param image
+ * @param pixelW
+ * @param pixelH
+ * @return
+ */
+ public static Bitmap compressBitmapByBmp(Bitmap image, float pixelW, float pixelH) {
+ ByteArrayOutputStream os = new ByteArrayOutputStream();
+ image.compress(Bitmap.CompressFormat.JPEG, 100, os);
+ if( os.toByteArray().length / 1024>1024) {//判断如果图片大于1M,进行压缩避免在生成图片(BitmapFactory.decodeStream)时溢出
+ os.reset();//重置baos即清空baos
+ image.compress(Bitmap.CompressFormat.JPEG, 50, os);//这里压缩50%,把压缩后的数据存放到baos中
+ }
+ ByteArrayInputStream is = new ByteArrayInputStream(os.toByteArray());
+ BitmapFactory.Options newOpts = new BitmapFactory.Options();
+ //开始读入图片,此时把options.inJustDecodeBounds 设回true了
+ newOpts.inJustDecodeBounds = true;
+ newOpts.inPreferredConfig = Bitmap.Config.RGB_565;
+ Bitmap bitmap = BitmapFactory.decodeStream(is, null, newOpts);
+ newOpts.inJustDecodeBounds = false;
+ int w = newOpts.outWidth;
+ int h = newOpts.outHeight;
+ float hh = pixelH;// 设置高度为240f时,可以明显看到图片缩小了
+ float ww = pixelW;// 设置宽度为120f,可以明显看到图片缩小了
+ //缩放比。由于是固定比例缩放,只用高或者宽其中一个数据进行计算即可
+ int be = 1;//be=1表示不缩放
+ if (w > h && w > ww) {//如果宽度大的话根据宽度固定大小缩放
+ be = (int) (newOpts.outWidth / ww);
+ } else if (w < h && h > hh) {//如果高度高的话根据宽度固定大小缩放
+ be = (int) (newOpts.outHeight / hh);
+ }
+ if (be <= 0) be = 1;
+ newOpts.inSampleSize = be;//设置缩放比例
+ //重新读入图片,注意此时已经把options.inJustDecodeBounds 设回false了
+ is = new ByteArrayInputStream(os.toByteArray());
+ bitmap = BitmapFactory.decodeStream(is, null, newOpts);
+ int desWidth = (int) (w / be);
+ int desHeight = (int) (h / be);
+ bitmap = Bitmap.createScaledBitmap(bitmap, desWidth, desHeight, true);
+ //压缩好比例大小后再进行质量压缩
+// return compress(bitmap, maxSize); // 这里再进行质量压缩的意义不大,反而耗资源,删除
+ return bitmap;
+ }
+
+ /**
+ * 质量压缩
+ * @param image
+ * @param maxSize
+ */
+ public static Bitmap compressImage(Bitmap image, int maxSize){
+ ByteArrayOutputStream os = new ByteArrayOutputStream();
+ // scale
+ int options = 80;
+ // Store the bitmap into output stream(no compress)
+ image.compress(Bitmap.CompressFormat.JPEG, options, os);
+ // Compress by loop
+ while ( os.toByteArray().length / 1024 > maxSize) {
+ // Clean up os
+ os.reset();
+ // interval 10
+ options -= 10;
+ image.compress(Bitmap.CompressFormat.JPEG, options, os);
+ }
+
+ Bitmap bitmap = null;
+ byte[] b = os.toByteArray();
+ if (b.length != 0) {
+ bitmap = BitmapFactory.decodeByteArray(b, 0, b.length);
+ }
+ return bitmap;
+ }
+
+ /**
+ * 对图片进行缩放
+ * @param bgimage
+ * @param newWidth
+ * @param newHeight
+ * @return
+ */
+ public static Bitmap zoomImage(Bitmap bgimage, double newWidth, double newHeight) {
+ // 获取这个图片的宽和高
+ float width = bgimage.getWidth();
+ float height = bgimage.getHeight();
+ //如果宽度为0 保持原图
+ if(newWidth == 0){
+ newWidth = width;
+ newHeight = height;
+ }
+ // 创建操作图片用的matrix对象
+ Matrix matrix = new Matrix();
+ // 计算宽高缩放率
+ float scaleWidth = ((float) newWidth) / width;
+ float scaleHeight = ((float) newHeight) / height;
+ // 缩放图片动作
+ matrix.postScale(scaleWidth, scaleHeight);
+ Bitmap bitmap = Bitmap.createBitmap(bgimage, 0, 0, (int) width,
+ (int) height, matrix, true);
+ bitmap = compressImage(bitmap, 100);//质量压缩
+ return bitmap;
+ }
+}
diff --git a/src/src/app/src/main/java/net/micode/notes/tool/ResourceParser.java b/src/src/app/src/main/java/net/micode/notes/tool/ResourceParser.java
new file mode 100644
index 0000000..7ad3318
--- /dev/null
+++ b/src/src/app/src/main/java/net/micode/notes/tool/ResourceParser.java
@@ -0,0 +1,193 @@
+/*
+ * Copyright (c) 2010-2011, The MiCode Open Source Community (www.micode.net)
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+
+package net.micode.notes.tool;
+
+
+import android.content.Context;
+import android.preference.PreferenceManager;
+import android.util.Log;
+
+import java.security.SecureRandom;
+
+import net.micode.notes.R;
+import net.micode.notes.ui.NotesPreferenceActivity;
+
+public class ResourceParser {
+
+ public static final int YELLOW = 0;
+ public static final int BLUE = 1;
+ public static final int WHITE = 2;
+ public static final int GREEN = 3;
+ public static final int RED = 4;
+
+ public static final int BG_DEFAULT_COLOR = YELLOW;
+
+ public static final int TEXT_SMALL = 0;
+ public static final int TEXT_MEDIUM = 1;
+ public static final int TEXT_LARGE = 2;
+ public static final int TEXT_SUPER = 3;
+
+ public static final int BG_DEFAULT_FONT_SIZE = TEXT_MEDIUM;
+
+ public static class NoteBgResources {
+ private final static int [] BG_EDIT_RESOURCES = new int [] {
+ R.drawable.edit_yellow,
+ R.drawable.edit_blue,
+ R.drawable.edit_white,
+ R.drawable.edit_green,
+ R.drawable.edit_red
+ };
+
+ private final static int [] BG_EDIT_TITLE_RESOURCES = new int [] {
+ R.drawable.edit_title_yellow,
+ R.drawable.edit_title_blue,
+ R.drawable.edit_title_white,
+ R.drawable.edit_title_green,
+ R.drawable.edit_title_red
+ };
+
+ public static int getNoteBgResource(int id) {
+ return BG_EDIT_RESOURCES[id];
+ }
+
+ public static int getNoteTitleBgResource(int id) {
+ return BG_EDIT_TITLE_RESOURCES[id];
+ }
+ }
+
+ public static int getDefaultBgId(Context context) {
+ if (PreferenceManager.getDefaultSharedPreferences(context).getBoolean(
+ NotesPreferenceActivity.PREFERENCE_SET_BG_COLOR_KEY, false)) {
+ try {
+ SecureRandom random = new SecureRandom();
+ return (int) ( random.nextInt() * NoteBgResources.BG_EDIT_RESOURCES.length);
+ }catch (NullPointerException e){
+ //e.printStackTrace();
+ Log.e("ResourceParser", "getDefaultBgId: " + e.toString() );
+ return BG_DEFAULT_COLOR;
+ }
+
+ } else {
+ return BG_DEFAULT_COLOR;
+ }
+ }
+
+ public static class NoteItemBgResources {
+ private final static int [] BG_FIRST_RESOURCES = new int [] {
+ R.drawable.list_yellow_up,
+ R.drawable.list_blue_up,
+ R.drawable.list_white_up,
+ R.drawable.list_green_up,
+ R.drawable.list_red_up
+ };
+
+ private final static int [] BG_NORMAL_RESOURCES = new int [] {
+ R.drawable.list_yellow_middle,
+ R.drawable.list_blue_middle,
+ R.drawable.list_white_middle,
+ R.drawable.list_green_middle,
+ R.drawable.list_red_middle
+ };
+
+ private final static int [] BG_LAST_RESOURCES = new int [] {
+ R.drawable.list_yellow_down,
+ R.drawable.list_blue_down,
+ R.drawable.list_white_down,
+ R.drawable.list_green_down,
+ R.drawable.list_red_down,
+ };
+
+ private final static int [] BG_SINGLE_RESOURCES = new int [] {
+ R.drawable.list_yellow_single,
+ R.drawable.list_blue_single,
+ R.drawable.list_white_single,
+ R.drawable.list_green_single,
+ R.drawable.list_red_single
+ };
+
+ public static int getNoteBgFirstRes(int id) {
+ return BG_FIRST_RESOURCES[id];
+ }
+
+ public static int getNoteBgLastRes(int id) {
+ return BG_LAST_RESOURCES[id];
+ }
+
+ public static int getNoteBgSingleRes(int id) {
+ return BG_SINGLE_RESOURCES[id];
+ }
+
+ public static int getNoteBgNormalRes(int id) {
+ return BG_NORMAL_RESOURCES[id];
+ }
+
+ public static int getFolderBgRes() {
+ return R.drawable.list_folder;
+ }
+ }
+
+ public static class WidgetBgResources {
+ private final static int [] BG_2X_RESOURCES = new int [] {
+ R.drawable.widget_2x_yellow,
+ R.drawable.widget_2x_blue,
+ R.drawable.widget_2x_white,
+ R.drawable.widget_2x_green,
+ R.drawable.widget_2x_red,
+ };
+
+ public static int getWidget2xBgResource(int id) {
+ return BG_2X_RESOURCES[id];
+ }
+
+ private final static int [] BG_4X_RESOURCES = new int [] {
+ R.drawable.widget_4x_yellow,
+ R.drawable.widget_4x_blue,
+ R.drawable.widget_4x_white,
+ R.drawable.widget_4x_green,
+ R.drawable.widget_4x_red
+ };
+
+ public static int getWidget4xBgResource(int id) {
+ return BG_4X_RESOURCES[id];
+ }
+ }
+
+ public static class TextAppearanceResources {
+ private final static int [] TEXTAPPEARANCE_RESOURCES = new int [] {
+ R.style.TextAppearanceNormal,
+ R.style.TextAppearanceMedium,
+ R.style.TextAppearanceLarge,
+ R.style.TextAppearanceSuper
+ };
+
+ public static int getTexAppearanceResource(int id) {
+ /**
+ * HACKME: Fix bug of store the resource id in shared preference.
+ * The id may larger than the length of resources, in this case,
+ * return the {@link ResourceParser#BG_DEFAULT_FONT_SIZE}
+ */
+ if (id >= TEXTAPPEARANCE_RESOURCES.length) {
+ return BG_DEFAULT_FONT_SIZE;
+ }
+ return TEXTAPPEARANCE_RESOURCES[id];
+ }
+
+ public static int getResourcesSize() {
+ return TEXTAPPEARANCE_RESOURCES.length;
+ }
+ }
+}
diff --git a/src/src/app/src/main/java/net/micode/notes/tool/ScreenUtils.java b/src/src/app/src/main/java/net/micode/notes/tool/ScreenUtils.java
new file mode 100644
index 0000000..bd59390
--- /dev/null
+++ b/src/src/app/src/main/java/net/micode/notes/tool/ScreenUtils.java
@@ -0,0 +1,97 @@
+package net.micode.notes.tool;
+
+import android.app.Activity;
+import android.content.Context;
+import android.graphics.Bitmap;
+import android.graphics.Rect;
+import android.util.DisplayMetrics;
+import android.view.View;
+import android.view.WindowManager;
+//mine 97
+/**
+ * Created by sendtion on 2016/5/25.
+ */
+public class ScreenUtils {
+
+ /**
+ * 获得屏幕宽度
+ * @param context
+ * @return
+ */
+ public static int getScreenWidth(Context context)
+ {
+ WindowManager wm = (WindowManager) context.getSystemService(Context.WINDOW_SERVICE);
+ DisplayMetrics outMetrics = new DisplayMetrics();
+ wm.getDefaultDisplay().getMetrics(outMetrics);
+ return outMetrics.widthPixels;
+ }
+
+ /**
+ * 获得屏幕高度
+ * @param context
+ * @return
+ */
+ public static int getScreenHeight(Context context) {
+ WindowManager wm = (WindowManager) context
+ .getSystemService(Context.WINDOW_SERVICE);
+ DisplayMetrics outMetrics = new DisplayMetrics();
+ wm.getDefaultDisplay().getMetrics(outMetrics);
+ return outMetrics.heightPixels;
+ }
+
+ /**
+ * 获得状态栏高度
+ * @param context
+ * @return
+ */
+ public static int getStatusHeight(Context context) {
+ int statusHeight = -1;
+ try {
+ Class> clazz = Class.forName("com.android.internal.R$dimen");
+ Object object = clazz.newInstance();
+ int height = Integer.parseInt(clazz.getField("status_bar_height")
+ .get(object).toString());
+ statusHeight = context.getResources().getDimensionPixelSize(height);
+ } catch (Exception e) {
+ e.printStackTrace();
+ }
+ return statusHeight;
+ }
+
+ /**
+ * 获取当前屏幕截图,包含状态栏
+ */
+ public static Bitmap snapShotWithStatusBar(Activity activity){
+ View view = activity.getWindow().getDecorView();
+ view.setDrawingCacheEnabled(true);
+ view.buildDrawingCache();
+ Bitmap bmp = view.getDrawingCache();
+ int width = getScreenWidth(activity);
+ int height = getScreenHeight(activity);
+ Bitmap bp = null;
+ bp = Bitmap.createBitmap(bmp, 0, 0, width, height);
+ view.destroyDrawingCache();
+ return bp;
+ }
+
+ /**
+ * 获取当前屏幕截图,不包含状态栏
+ *
+ */
+ public static Bitmap snapShotWithoutStatusBar(Activity activity){
+ View view = activity.getWindow().getDecorView();
+ view.setDrawingCacheEnabled(true);
+ view.buildDrawingCache();
+ Bitmap bmp = view.getDrawingCache();
+ Rect frame = new Rect();
+ activity.getWindow().getDecorView().getWindowVisibleDisplayFrame(frame);
+ int statusBarHeight = frame.top;
+ int width = getScreenWidth(activity);
+ int height = getScreenHeight(activity);
+ Bitmap bp = null;
+ bp = Bitmap.createBitmap(bmp, 0, statusBarHeight, width, height
+ - statusBarHeight);
+ view.destroyDrawingCache();
+ return bp;
+ }
+}
diff --git a/src/src/app/src/main/java/net/micode/notes/ui/AlarmAlertActivity.java b/src/src/app/src/main/java/net/micode/notes/ui/AlarmAlertActivity.java
new file mode 100644
index 0000000..d84b279
--- /dev/null
+++ b/src/src/app/src/main/java/net/micode/notes/ui/AlarmAlertActivity.java
@@ -0,0 +1,167 @@
+/*
+ * Copyright (c) 2010-2011, The MiCode Open Source Community (www.micode.net)
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+
+package net.micode.notes.ui;
+
+import android.app.Activity;
+import android.app.AlertDialog;
+import android.content.Context;
+import android.content.DialogInterface;
+import android.content.DialogInterface.OnClickListener;
+import android.content.DialogInterface.OnDismissListener;
+import android.content.Intent;
+import android.media.AudioManager;
+import android.media.MediaPlayer;
+import android.media.RingtoneManager;
+import android.net.Uri;
+import android.os.Bundle;
+import android.os.PowerManager;
+import android.provider.Settings;
+import android.util.Log;
+import android.view.Window;
+import android.view.WindowManager;
+
+import net.micode.notes.R;
+import net.micode.notes.data.Notes;
+import net.micode.notes.tool.DataUtils;
+
+import java.io.IOException;
+
+import static net.micode.notes.data.Notes.TAG;
+
+
+public class AlarmAlertActivity extends Activity implements OnClickListener, OnDismissListener {
+ private long mNoteId;
+ private String mSnippet;
+ private static final int SNIPPET_PREW_MAX_LEN = 60;
+ MediaPlayer mPlayer;
+
+ @Override
+ protected void onCreate(Bundle savedInstanceState) {//提醒的时候才会创建活动
+ super.onCreate(savedInstanceState);
+ requestWindowFeature(Window.FEATURE_NO_TITLE);
+
+ final Window win = getWindow();
+ win.addFlags(WindowManager.LayoutParams.FLAG_SHOW_WHEN_LOCKED);//浮在界面上面
+
+ if (!isScreenOn()) {
+ win.addFlags(WindowManager.LayoutParams.FLAG_KEEP_SCREEN_ON
+ | WindowManager.LayoutParams.FLAG_TURN_SCREEN_ON
+ | WindowManager.LayoutParams.FLAG_ALLOW_LOCK_WHILE_SCREEN_ON
+ | WindowManager.LayoutParams.FLAG_LAYOUT_INSET_DECOR);
+ }
+
+ Intent intent = getIntent();//通过getIntent()获得的Intent用于开启Activity
+
+ try {
+ mNoteId = Long.valueOf(intent.getData().getPathSegments().get(1));
+ mSnippet = DataUtils.getSnippetById(this.getContentResolver(), mNoteId);
+ mSnippet = mSnippet.length() > SNIPPET_PREW_MAX_LEN ? mSnippet.substring(0,
+ SNIPPET_PREW_MAX_LEN) + getResources().getString(R.string.notelist_string_info)
+ : mSnippet;
+ } catch (IllegalArgumentException e) {
+ //e.printStackTrace();
+ Log.e(TAG, "onCreate: " + e.toString() );
+ return;
+ }
+
+ mPlayer = new MediaPlayer();
+ Log.e(TAG,"this");
+ if (DataUtils.visibleInNoteDatabase(getContentResolver(), mNoteId, Notes.TYPE_NOTE)) {
+ showActionDialog();
+ playAlarmSound();
+ } else {
+ finish();
+ }
+ }
+
+ private boolean isScreenOn() {//电源管理器,判断是否锁屏
+ PowerManager pm = (PowerManager) getSystemService(Context.POWER_SERVICE);
+ return pm.isScreenOn();
+ }
+
+ private void playAlarmSound() {
+ Uri url = RingtoneManager.getActualDefaultRingtoneUri(this, RingtoneManager.TYPE_ALARM);
+
+ int silentModeStreams = Settings.System.getInt(getContentResolver(),
+ Settings.System.MODE_RINGER_STREAMS_AFFECTED, 0);
+
+ if ((silentModeStreams & (1 << AudioManager.STREAM_ALARM)) != 0) {
+ mPlayer.setAudioStreamType(silentModeStreams);
+ } else {
+ mPlayer.setAudioStreamType(AudioManager.STREAM_ALARM);
+ }
+ try {
+ mPlayer.setDataSource(this, url);
+ mPlayer.prepare();
+ mPlayer.setLooping(true);
+ mPlayer.start();
+ } catch (IllegalArgumentException e) {
+ // TODO Auto-generated catch block
+ //e.printStackTrace();
+ Log.e(TAG, "playAlarmSound: " + e.toString() );
+ } catch (SecurityException e) {
+ // TODO Auto-generated catch block
+ //e.printStackTrace();
+ Log.e(TAG, "playAlarmSound: " + e.toString() );
+ } catch (IllegalStateException e) {
+ // TODO Auto-generated catch block
+ //e.printStackTrace();
+ Log.e(TAG, "playAlarmSound: " + e.toString() );
+ } catch (IOException e) {
+ // TODO Auto-generated catch block
+ //e.printStackTrace();
+ Log.e(TAG, "playAlarmSound: " + e.toString() );
+ }
+ }
+
+ private void showActionDialog() {
+ AlertDialog.Builder dialog = new AlertDialog.Builder(this);
+ dialog.setTitle(R.string.app_name);
+ dialog.setMessage(mSnippet);
+ dialog.setPositiveButton(R.string.notealert_ok, this);
+ if (isScreenOn()) {
+ dialog.setNegativeButton(R.string.notealert_enter, this);
+ }
+ dialog.show().setOnDismissListener(this);
+ }
+
+ public void onClick(DialogInterface dialog, int which) {
+ switch (which) {
+ case DialogInterface.BUTTON_NEGATIVE:
+ Intent intent = new Intent(this, NoteEditActivity.class);
+ intent.setAction(Intent.ACTION_VIEW);
+ intent.putExtra(Intent.EXTRA_UID, mNoteId);
+ startActivity(intent);
+ break;
+ default:
+ break;
+ }
+ }
+
+ public void onDismiss(DialogInterface dialog) {
+ stopAlarmSound();
+ finish();
+ }
+
+ private void stopAlarmSound() {
+ if (mPlayer != null) {
+ mPlayer.stop();
+ mPlayer.release();
+ mPlayer = null;
+ }
+ }
+}
diff --git a/src/src/app/src/main/java/net/micode/notes/ui/AlarmInitReceiver.java b/src/src/app/src/main/java/net/micode/notes/ui/AlarmInitReceiver.java
new file mode 100644
index 0000000..f221202
--- /dev/null
+++ b/src/src/app/src/main/java/net/micode/notes/ui/AlarmInitReceiver.java
@@ -0,0 +1,65 @@
+/*
+ * Copyright (c) 2010-2011, The MiCode Open Source Community (www.micode.net)
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+
+package net.micode.notes.ui;
+
+import android.app.AlarmManager;
+import android.app.PendingIntent;
+import android.content.BroadcastReceiver;
+import android.content.ContentUris;
+import android.content.Context;
+import android.content.Intent;
+import android.database.Cursor;
+
+import net.micode.notes.data.Notes;
+import net.micode.notes.data.Notes.NoteColumns;
+
+
+public class AlarmInitReceiver extends BroadcastReceiver {
+
+ private static final String [] PROJECTION = new String [] {
+ NoteColumns.ID,
+ NoteColumns.ALERTED_DATE
+ };
+
+ private static final int COLUMN_ID = 0;
+ private static final int COLUMN_ALERTED_DATE = 1;
+
+ @Override
+ public void onReceive(Context context, Intent intent) {
+ long currentDate = System.currentTimeMillis();
+ Cursor c = context.getContentResolver().query(Notes.CONTENT_NOTE_URI,
+ PROJECTION,
+ NoteColumns.ALERTED_DATE + ">? AND " + NoteColumns.TYPE + "=" + Notes.TYPE_NOTE,
+ new String[] { String.valueOf(currentDate) },
+ null);
+
+ if (c != null) {
+ if (c.moveToFirst()) {
+ do {
+ long alertDate = c.getLong(COLUMN_ALERTED_DATE);
+ Intent sender = new Intent(context, AlarmReceiver.class);
+ sender.setData(ContentUris.withAppendedId(Notes.CONTENT_NOTE_URI, c.getLong(COLUMN_ID)));
+ PendingIntent pendingIntent = PendingIntent.getBroadcast(context, 0, sender, 0);
+ AlarmManager alermManager = (AlarmManager) context
+ .getSystemService(Context.ALARM_SERVICE);
+ alermManager.set(AlarmManager.RTC_WAKEUP, alertDate, pendingIntent);
+ } while (c.moveToNext());
+ }
+ c.close();
+ }
+ }
+}
diff --git a/src/src/app/src/main/java/net/micode/notes/ui/AlarmReceiver.java b/src/src/app/src/main/java/net/micode/notes/ui/AlarmReceiver.java
new file mode 100644
index 0000000..54e503b
--- /dev/null
+++ b/src/src/app/src/main/java/net/micode/notes/ui/AlarmReceiver.java
@@ -0,0 +1,30 @@
+/*
+ * Copyright (c) 2010-2011, The MiCode Open Source Community (www.micode.net)
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+
+package net.micode.notes.ui;
+
+import android.content.BroadcastReceiver;
+import android.content.Context;
+import android.content.Intent;
+
+public class AlarmReceiver extends BroadcastReceiver {
+ @Override
+ public void onReceive(Context context, Intent intent) {
+ intent.setClass(context, AlarmAlertActivity.class);
+ intent.addFlags(Intent.FLAG_ACTIVITY_NEW_TASK);
+ context.startActivity(intent);
+ }
+}
diff --git a/src/src/app/src/main/java/net/micode/notes/ui/DateTimePicker.java b/src/src/app/src/main/java/net/micode/notes/ui/DateTimePicker.java
new file mode 100644
index 0000000..496b0cd
--- /dev/null
+++ b/src/src/app/src/main/java/net/micode/notes/ui/DateTimePicker.java
@@ -0,0 +1,485 @@
+/*
+ * Copyright (c) 2010-2011, The MiCode Open Source Community (www.micode.net)
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+
+package net.micode.notes.ui;
+
+import java.text.DateFormatSymbols;
+import java.util.Calendar;
+
+import net.micode.notes.R;
+
+
+import android.content.Context;
+import android.text.format.DateFormat;
+import android.view.View;
+import android.widget.FrameLayout;
+import android.widget.NumberPicker;
+
+public class DateTimePicker extends FrameLayout {
+
+ private static final boolean DEFAULT_ENABLE_STATE = true;
+
+ private static final int HOURS_IN_HALF_DAY = 12;
+ private static final int HOURS_IN_ALL_DAY = 24;
+ private static final int DAYS_IN_ALL_WEEK = 7;
+ private static final int DATE_SPINNER_MIN_VAL = 0;
+ private static final int DATE_SPINNER_MAX_VAL = DAYS_IN_ALL_WEEK - 1;
+ private static final int HOUR_SPINNER_MIN_VAL_24_HOUR_VIEW = 0;
+ private static final int HOUR_SPINNER_MAX_VAL_24_HOUR_VIEW = 23;
+ private static final int HOUR_SPINNER_MIN_VAL_12_HOUR_VIEW = 1;
+ private static final int HOUR_SPINNER_MAX_VAL_12_HOUR_VIEW = 12;
+ private static final int MINUT_SPINNER_MIN_VAL = 0;
+ private static final int MINUT_SPINNER_MAX_VAL = 59;
+ private static final int AMPM_SPINNER_MIN_VAL = 0;
+ private static final int AMPM_SPINNER_MAX_VAL = 1;
+
+ private final NumberPicker mDateSpinner;
+ private final NumberPicker mHourSpinner;
+ private final NumberPicker mMinuteSpinner;
+ private final NumberPicker mAmPmSpinner;
+ private Calendar mDate;
+
+ private String[] mDateDisplayValues = new String[DAYS_IN_ALL_WEEK];
+
+ private boolean mIsAm;
+
+ private boolean mIs24HourView;
+
+ private boolean mIsEnabled = DEFAULT_ENABLE_STATE;
+
+ private boolean mInitialising;
+
+ private OnDateTimeChangedListener mOnDateTimeChangedListener;
+
+ private NumberPicker.OnValueChangeListener mOnDateChangedListener = new NumberPicker.OnValueChangeListener() {
+ @Override
+ public void onValueChange(NumberPicker picker, int oldVal, int newVal) {
+ mDate.add(Calendar.DAY_OF_YEAR, newVal - oldVal);
+ updateDateControl();
+ onDateTimeChanged();
+ }
+ };
+
+ private NumberPicker.OnValueChangeListener mOnHourChangedListener = new NumberPicker.OnValueChangeListener() {
+ @Override
+ public void onValueChange(NumberPicker picker, int oldVal, int newVal) {
+ boolean isDateChanged = false;
+ Calendar cal = Calendar.getInstance();
+ if (!mIs24HourView) {
+ if (!mIsAm && oldVal == HOURS_IN_HALF_DAY - 1 && newVal == HOURS_IN_HALF_DAY) {
+ cal.setTimeInMillis(mDate.getTimeInMillis());
+ cal.add(Calendar.DAY_OF_YEAR, 1);
+ isDateChanged = true;
+ } else if (mIsAm && oldVal == HOURS_IN_HALF_DAY && newVal == HOURS_IN_HALF_DAY - 1) {
+ cal.setTimeInMillis(mDate.getTimeInMillis());
+ cal.add(Calendar.DAY_OF_YEAR, -1);
+ isDateChanged = true;
+ }
+ if (oldVal == HOURS_IN_HALF_DAY - 1 && newVal == HOURS_IN_HALF_DAY ||
+ oldVal == HOURS_IN_HALF_DAY && newVal == HOURS_IN_HALF_DAY - 1) {
+ mIsAm = !mIsAm;
+ updateAmPmControl();
+ }
+ } else {
+ if (oldVal == HOURS_IN_ALL_DAY - 1 && newVal == 0) {
+ cal.setTimeInMillis(mDate.getTimeInMillis());
+ cal.add(Calendar.DAY_OF_YEAR, 1);
+ isDateChanged = true;
+ } else if (oldVal == 0 && newVal == HOURS_IN_ALL_DAY - 1) {
+ cal.setTimeInMillis(mDate.getTimeInMillis());
+ cal.add(Calendar.DAY_OF_YEAR, -1);
+ isDateChanged = true;
+ }
+ }
+ int newHour = mHourSpinner.getValue() % HOURS_IN_HALF_DAY + (mIsAm ? 0 : HOURS_IN_HALF_DAY);
+ mDate.set(Calendar.HOUR_OF_DAY, newHour);
+ onDateTimeChanged();
+ if (isDateChanged) {
+ setCurrentYear(cal.get(Calendar.YEAR));
+ setCurrentMonth(cal.get(Calendar.MONTH));
+ setCurrentDay(cal.get(Calendar.DAY_OF_MONTH));
+ }
+ }
+ };
+
+ private NumberPicker.OnValueChangeListener mOnMinuteChangedListener = new NumberPicker.OnValueChangeListener() {
+ @Override
+ public void onValueChange(NumberPicker picker, int oldVal, int newVal) {
+ int minValue = mMinuteSpinner.getMinValue();
+ int maxValue = mMinuteSpinner.getMaxValue();
+ int offset = 0;
+ if (oldVal == maxValue && newVal == minValue) {
+ offset += 1;
+ } else if (oldVal == minValue && newVal == maxValue) {
+ offset -= 1;
+ }
+ if (offset != 0) {
+ mDate.add(Calendar.HOUR_OF_DAY, offset);
+ mHourSpinner.setValue(getCurrentHour());
+ updateDateControl();
+ int newHour = getCurrentHourOfDay();
+ if (newHour >= HOURS_IN_HALF_DAY) {
+ mIsAm = false;
+ updateAmPmControl();
+ } else {
+ mIsAm = true;
+ updateAmPmControl();
+ }
+ }
+ mDate.set(Calendar.MINUTE, newVal);
+ onDateTimeChanged();
+ }
+ };
+
+ private NumberPicker.OnValueChangeListener mOnAmPmChangedListener = new NumberPicker.OnValueChangeListener() {
+ @Override
+ public void onValueChange(NumberPicker picker, int oldVal, int newVal) {
+ mIsAm = !mIsAm;
+ if (mIsAm) {
+ mDate.add(Calendar.HOUR_OF_DAY, -HOURS_IN_HALF_DAY);
+ } else {
+ mDate.add(Calendar.HOUR_OF_DAY, HOURS_IN_HALF_DAY);
+ }
+ updateAmPmControl();
+ onDateTimeChanged();
+ }
+ };
+
+ public interface OnDateTimeChangedListener {
+ void onDateTimeChanged(DateTimePicker view, int year, int month,
+ int dayOfMonth, int hourOfDay, int minute);
+ }
+
+ public DateTimePicker(Context context) {
+ this(context, System.currentTimeMillis());
+ }
+
+ public DateTimePicker(Context context, long date) {
+ this(context, date, DateFormat.is24HourFormat(context));
+ }
+
+ public DateTimePicker(Context context, long date, boolean is24HourView) {
+ super(context);
+ mDate = Calendar.getInstance();
+ mInitialising = true;
+ mIsAm = getCurrentHourOfDay() >= HOURS_IN_HALF_DAY;
+ inflate(context, R.layout.datetime_picker, this);
+
+ mDateSpinner = (NumberPicker) findViewById(R.id.date);
+ mDateSpinner.setMinValue(DATE_SPINNER_MIN_VAL);
+ mDateSpinner.setMaxValue(DATE_SPINNER_MAX_VAL);
+ mDateSpinner.setOnValueChangedListener(mOnDateChangedListener);
+
+ mHourSpinner = (NumberPicker) findViewById(R.id.hour);
+ mHourSpinner.setOnValueChangedListener(mOnHourChangedListener);
+ mMinuteSpinner = (NumberPicker) findViewById(R.id.minute);
+ mMinuteSpinner.setMinValue(MINUT_SPINNER_MIN_VAL);
+ mMinuteSpinner.setMaxValue(MINUT_SPINNER_MAX_VAL);
+ mMinuteSpinner.setOnLongPressUpdateInterval(100);
+ mMinuteSpinner.setOnValueChangedListener(mOnMinuteChangedListener);
+
+ String[] stringsForAmPm = new DateFormatSymbols().getAmPmStrings();
+ mAmPmSpinner = (NumberPicker) findViewById(R.id.amPm);
+ mAmPmSpinner.setMinValue(AMPM_SPINNER_MIN_VAL);
+ mAmPmSpinner.setMaxValue(AMPM_SPINNER_MAX_VAL);
+ mAmPmSpinner.setDisplayedValues(stringsForAmPm);
+ mAmPmSpinner.setOnValueChangedListener(mOnAmPmChangedListener);
+
+ // update controls to initial state
+ updateDateControl();
+ updateHourControl();
+ updateAmPmControl();
+
+ set24HourView(is24HourView);
+
+ // set to current time
+ setCurrentDate(date);
+
+ setEnabled(isEnabled());
+
+ // set the content descriptions
+ mInitialising = false;
+ }
+
+ @Override
+ public void setEnabled(boolean enabled) {
+ if (mIsEnabled == enabled) {
+ return;
+ }
+ super.setEnabled(enabled);
+ mDateSpinner.setEnabled(enabled);
+ mMinuteSpinner.setEnabled(enabled);
+ mHourSpinner.setEnabled(enabled);
+ mAmPmSpinner.setEnabled(enabled);
+ mIsEnabled = enabled;
+ }
+
+ @Override
+ public boolean isEnabled() {
+ return mIsEnabled;
+ }
+
+ /**
+ * Get the current date in millis
+ *
+ * @return the current date in millis
+ */
+ public long getCurrentDateInTimeMillis() {
+ return mDate.getTimeInMillis();
+ }
+
+ /**
+ * Set the current date
+ *
+ * @param date The current date in millis
+ */
+ public void setCurrentDate(long date) {
+ Calendar cal = Calendar.getInstance();
+ cal.setTimeInMillis(date);
+ setCurrentDate(cal.get(Calendar.YEAR), cal.get(Calendar.MONTH), cal.get(Calendar.DAY_OF_MONTH),
+ cal.get(Calendar.HOUR_OF_DAY), cal.get(Calendar.MINUTE));
+ }
+
+ /**
+ * Set the current date
+ *
+ * @param year The current year
+ * @param month The current month
+ * @param dayOfMonth The current dayOfMonth
+ * @param hourOfDay The current hourOfDay
+ * @param minute The current minute
+ */
+ public void setCurrentDate(int year, int month,
+ int dayOfMonth, int hourOfDay, int minute) {
+ setCurrentYear(year);
+ setCurrentMonth(month);
+ setCurrentDay(dayOfMonth);
+ setCurrentHour(hourOfDay);
+ setCurrentMinute(minute);
+ }
+
+ /**
+ * Get current year
+ *
+ * @return The current year
+ */
+ public int getCurrentYear() {
+ return mDate.get(Calendar.YEAR);
+ }
+
+ /**
+ * Set current year
+ *
+ * @param year The current year
+ */
+ public void setCurrentYear(int year) {
+ if (!mInitialising && year == getCurrentYear()) {
+ return;
+ }
+ mDate.set(Calendar.YEAR, year);
+ updateDateControl();
+ onDateTimeChanged();
+ }
+
+ /**
+ * Get current month in the year
+ *
+ * @return The current month in the year
+ */
+ public int getCurrentMonth() {
+ return mDate.get(Calendar.MONTH);
+ }
+
+ /**
+ * Set current month in the year
+ *
+ * @param month The month in the year
+ */
+ public void setCurrentMonth(int month) {
+ if (!mInitialising && month == getCurrentMonth()) {
+ return;
+ }
+ mDate.set(Calendar.MONTH, month);
+ updateDateControl();
+ onDateTimeChanged();
+ }
+
+ /**
+ * Get current day of the month
+ *
+ * @return The day of the month
+ */
+ public int getCurrentDay() {
+ return mDate.get(Calendar.DAY_OF_MONTH);
+ }
+
+ /**
+ * Set current day of the month
+ *
+ * @param dayOfMonth The day of the month
+ */
+ public void setCurrentDay(int dayOfMonth) {
+ if (!mInitialising && dayOfMonth == getCurrentDay()) {
+ return;
+ }
+ mDate.set(Calendar.DAY_OF_MONTH, dayOfMonth);
+ updateDateControl();
+ onDateTimeChanged();
+ }
+
+ /**
+ * Get current hour in 24 hour mode, in the range (0~23)
+ * @return The current hour in 24 hour mode
+ */
+ public int getCurrentHourOfDay() {
+ return mDate.get(Calendar.HOUR_OF_DAY);
+ }
+
+ private int getCurrentHour() {
+ if (mIs24HourView){
+ return getCurrentHourOfDay();
+ } else {
+ int hour = getCurrentHourOfDay();
+ if (hour > HOURS_IN_HALF_DAY) {
+ return hour - HOURS_IN_HALF_DAY;
+ } else {
+ return hour == 0 ? HOURS_IN_HALF_DAY : hour;
+ }
+ }
+ }
+
+ /**
+ * Set current hour in 24 hour mode, in the range (0~23)
+ *
+ * @param hourOfDay
+ */
+ public void setCurrentHour(int hourOfDay) {
+ if (!mInitialising && hourOfDay == getCurrentHourOfDay()) {
+ return;
+ }
+ mDate.set(Calendar.HOUR_OF_DAY, hourOfDay);
+ if (!mIs24HourView) {
+ if (hourOfDay >= HOURS_IN_HALF_DAY) {
+ mIsAm = false;
+ if (hourOfDay > HOURS_IN_HALF_DAY) {
+ hourOfDay -= HOURS_IN_HALF_DAY;
+ }
+ } else {
+ mIsAm = true;
+ if (hourOfDay == 0) {
+ hourOfDay = HOURS_IN_HALF_DAY;
+ }
+ }
+ updateAmPmControl();
+ }
+ mHourSpinner.setValue(hourOfDay);
+ onDateTimeChanged();
+ }
+
+ /**
+ * Get currentMinute
+ *
+ * @return The Current Minute
+ */
+ public int getCurrentMinute() {
+ return mDate.get(Calendar.MINUTE);
+ }
+
+ /**
+ * Set current minute
+ */
+ public void setCurrentMinute(int minute) {
+ if (!mInitialising && minute == getCurrentMinute()) {
+ return;
+ }
+ mMinuteSpinner.setValue(minute);
+ mDate.set(Calendar.MINUTE, minute);
+ onDateTimeChanged();
+ }
+
+ /**
+ * @return true if this is in 24 hour view else false.
+ */
+ public boolean is24HourView () {
+ return mIs24HourView;
+ }
+
+ /**
+ * Set whether in 24 hour or AM/PM mode.
+ *
+ * @param is24HourView True for 24 hour mode. False for AM/PM mode.
+ */
+ public void set24HourView(boolean is24HourView) {
+ if (mIs24HourView == is24HourView) {
+ return;
+ }
+ mIs24HourView = is24HourView;
+ mAmPmSpinner.setVisibility(is24HourView ? View.GONE : View.VISIBLE);
+ int hour = getCurrentHourOfDay();
+ updateHourControl();
+ setCurrentHour(hour);
+ updateAmPmControl();
+ }
+
+ private void updateDateControl() {
+ Calendar cal = Calendar.getInstance();
+ cal.setTimeInMillis(mDate.getTimeInMillis());
+ cal.add(Calendar.DAY_OF_YEAR, -DAYS_IN_ALL_WEEK / 2 - 1);
+ mDateSpinner.setDisplayedValues(null);
+ for (int i = 0; i < DAYS_IN_ALL_WEEK; ++i) {
+ cal.add(Calendar.DAY_OF_YEAR, 1);
+ mDateDisplayValues[i] = (String) DateFormat.format("MM.dd EEEE", cal);
+ }
+ mDateSpinner.setDisplayedValues(mDateDisplayValues);
+ mDateSpinner.setValue(DAYS_IN_ALL_WEEK / 2);
+ mDateSpinner.invalidate();
+ }
+
+ private void updateAmPmControl() {
+ if (mIs24HourView) {
+ mAmPmSpinner.setVisibility(View.GONE);
+ } else {
+ int index = mIsAm ? Calendar.AM : Calendar.PM;
+ mAmPmSpinner.setValue(index);
+ mAmPmSpinner.setVisibility(View.VISIBLE);
+ }
+ }
+
+ private void updateHourControl() {
+ if (mIs24HourView) {
+ mHourSpinner.setMinValue(HOUR_SPINNER_MIN_VAL_24_HOUR_VIEW);
+ mHourSpinner.setMaxValue(HOUR_SPINNER_MAX_VAL_24_HOUR_VIEW);
+ } else {
+ mHourSpinner.setMinValue(HOUR_SPINNER_MIN_VAL_12_HOUR_VIEW);
+ mHourSpinner.setMaxValue(HOUR_SPINNER_MAX_VAL_12_HOUR_VIEW);
+ }
+ }
+
+ /**
+ * Set the callback that indicates the 'Set' button has been pressed.
+ * @param callback the callback, if null will do nothing
+ */
+ public void setOnDateTimeChangedListener(OnDateTimeChangedListener callback) {
+ mOnDateTimeChangedListener = callback;
+ }
+
+ private void onDateTimeChanged() {
+ if (mOnDateTimeChangedListener != null) {
+ mOnDateTimeChangedListener.onDateTimeChanged(this, getCurrentYear(),
+ getCurrentMonth(), getCurrentDay(), getCurrentHourOfDay(), getCurrentMinute());
+ }
+ }
+}
diff --git a/src/src/app/src/main/java/net/micode/notes/ui/DateTimePickerDialog.java b/src/src/app/src/main/java/net/micode/notes/ui/DateTimePickerDialog.java
new file mode 100644
index 0000000..fde6666
--- /dev/null
+++ b/src/src/app/src/main/java/net/micode/notes/ui/DateTimePickerDialog.java
@@ -0,0 +1,90 @@
+/*
+ * Copyright (c) 2010-2011, The MiCode Open Source Community (www.micode.net)
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+
+package net.micode.notes.ui;
+
+import java.util.Calendar;
+
+import net.micode.notes.R;
+import net.micode.notes.ui.DateTimePicker;
+import net.micode.notes.ui.DateTimePicker.OnDateTimeChangedListener;
+
+import android.app.AlertDialog;
+import android.content.Context;
+import android.content.DialogInterface;
+import android.content.DialogInterface.OnClickListener;
+import android.text.format.DateFormat;
+import android.text.format.DateUtils;
+
+public class DateTimePickerDialog extends AlertDialog implements OnClickListener {
+
+ private Calendar mDate = Calendar.getInstance();
+ private boolean mIs24HourView;
+ private OnDateTimeSetListener mOnDateTimeSetListener;
+ private DateTimePicker mDateTimePicker;
+
+ public interface OnDateTimeSetListener {
+ void OnDateTimeSet(AlertDialog dialog, long date);
+ }
+
+ public DateTimePickerDialog(Context context, long date) {
+ super(context);
+ mDateTimePicker = new DateTimePicker(context);
+ setView(mDateTimePicker);
+ mDateTimePicker.setOnDateTimeChangedListener(new OnDateTimeChangedListener() {
+ public void onDateTimeChanged(DateTimePicker view, int year, int month,
+ int dayOfMonth, int hourOfDay, int minute) {
+ mDate.set(Calendar.YEAR, year);
+ mDate.set(Calendar.MONTH, month);
+ mDate.set(Calendar.DAY_OF_MONTH, dayOfMonth);
+ mDate.set(Calendar.HOUR_OF_DAY, hourOfDay);
+ mDate.set(Calendar.MINUTE, minute);
+ updateTitle(mDate.getTimeInMillis());
+ }
+ });
+ mDate.setTimeInMillis(date);
+ mDate.set(Calendar.SECOND, 0);
+ mDateTimePicker.setCurrentDate(mDate.getTimeInMillis());
+ setButton(context.getString(R.string.datetime_dialog_ok), this);
+ setButton2(context.getString(R.string.datetime_dialog_cancel), (OnClickListener)null);
+ set24HourView(DateFormat.is24HourFormat(this.getContext()));
+ updateTitle(mDate.getTimeInMillis());
+ }
+
+ public void set24HourView(boolean is24HourView) {
+ mIs24HourView = is24HourView;
+ }
+
+ public void setOnDateTimeSetListener(OnDateTimeSetListener callBack) {
+ mOnDateTimeSetListener = callBack;
+ }
+
+ private void updateTitle(long date) {
+ int flag =
+ DateUtils.FORMAT_SHOW_YEAR |
+ DateUtils.FORMAT_SHOW_DATE |
+ DateUtils.FORMAT_SHOW_TIME;
+ flag |= mIs24HourView ? DateUtils.FORMAT_24HOUR : DateUtils.FORMAT_12HOUR;
+ setTitle(DateUtils.formatDateTime(this.getContext(), date, flag));
+ }
+
+ public void onClick(DialogInterface arg0, int arg1) {
+ if (mOnDateTimeSetListener != null) {
+ mOnDateTimeSetListener.OnDateTimeSet(this, mDate.getTimeInMillis());
+ }
+ }
+
+}
\ No newline at end of file
diff --git a/src/src/app/src/main/java/net/micode/notes/ui/DropdownMenu.java b/src/src/app/src/main/java/net/micode/notes/ui/DropdownMenu.java
new file mode 100644
index 0000000..613dc74
--- /dev/null
+++ b/src/src/app/src/main/java/net/micode/notes/ui/DropdownMenu.java
@@ -0,0 +1,61 @@
+/*
+ * Copyright (c) 2010-2011, The MiCode Open Source Community (www.micode.net)
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+
+package net.micode.notes.ui;
+
+import android.content.Context;
+import android.view.Menu;
+import android.view.MenuItem;
+import android.view.View;
+import android.view.View.OnClickListener;
+import android.widget.Button;
+import android.widget.PopupMenu;
+import android.widget.PopupMenu.OnMenuItemClickListener;
+
+import net.micode.notes.R;
+
+public class DropdownMenu {
+ private Button mButton;
+ private PopupMenu mPopupMenu;
+ private Menu mMenu;
+
+ public DropdownMenu(Context context, Button button, int menuId) {
+ mButton = button;
+ mButton.setBackgroundResource(R.drawable.dropdown_icon);
+ mPopupMenu = new PopupMenu(context, mButton);
+ mMenu = mPopupMenu.getMenu();
+ mPopupMenu.getMenuInflater().inflate(menuId, mMenu);
+ mButton.setOnClickListener(new OnClickListener() {
+ public void onClick(View v) {
+ mPopupMenu.show();
+ }
+ });
+ }
+
+ public void setOnDropdownMenuItemClickListener(OnMenuItemClickListener listener) {
+ if (mPopupMenu != null) {
+ mPopupMenu.setOnMenuItemClickListener(listener);
+ }
+ }
+
+ public MenuItem findItem(int id) {
+ return mMenu.findItem(id);
+ }
+
+ public void setTitle(CharSequence title) {
+ mButton.setText(title);
+ }
+}
diff --git a/src/src/app/src/main/java/net/micode/notes/ui/FoldersListAdapter.java b/src/src/app/src/main/java/net/micode/notes/ui/FoldersListAdapter.java
new file mode 100644
index 0000000..96b77da
--- /dev/null
+++ b/src/src/app/src/main/java/net/micode/notes/ui/FoldersListAdapter.java
@@ -0,0 +1,80 @@
+/*
+ * Copyright (c) 2010-2011, The MiCode Open Source Community (www.micode.net)
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+
+package net.micode.notes.ui;
+
+import android.content.Context;
+import android.database.Cursor;
+import android.view.View;
+import android.view.ViewGroup;
+import android.widget.CursorAdapter;
+import android.widget.LinearLayout;
+import android.widget.TextView;
+
+import net.micode.notes.R;
+import net.micode.notes.data.Notes;
+import net.micode.notes.data.Notes.NoteColumns;
+
+
+public class FoldersListAdapter extends CursorAdapter {
+ public static final String [] PROJECTION = {
+ NoteColumns.ID,
+ NoteColumns.SNIPPET
+ };
+
+ public static final int ID_COLUMN = 0;
+ public static final int NAME_COLUMN = 1;
+
+ public FoldersListAdapter(Context context, Cursor c) {
+ super(context, c);
+ // TODO Auto-generated constructor stub
+ }
+
+ @Override
+ public View newView(Context context, Cursor cursor, ViewGroup parent) {
+ return new FolderListItem(context);
+ }
+
+ @Override
+ public void bindView(View view, Context context, Cursor cursor) {
+ if (view instanceof FolderListItem) {
+ String folderName = (cursor.getLong(ID_COLUMN) == Notes.ID_ROOT_FOLDER) ? context
+ .getString(R.string.menu_move_parent_folder) : cursor.getString(NAME_COLUMN);
+ ((FolderListItem) view).bind(folderName);
+ }
+ }
+
+ public String getFolderName(Context context, int position) {
+ Cursor cursor = (Cursor) getItem(position);
+ return (cursor.getLong(ID_COLUMN) == Notes.ID_ROOT_FOLDER) ? context
+ .getString(R.string.menu_move_parent_folder) : cursor.getString(NAME_COLUMN);
+ }
+
+ private class FolderListItem extends LinearLayout {
+ private TextView mName;
+
+ public FolderListItem(Context context) {
+ super(context);
+ inflate(context, R.layout.folder_list_item, this);
+ mName = (TextView) findViewById(R.id.tv_folder_name);
+ }
+
+ public void bind(String name) {
+ mName.setText(name);
+ }
+ }
+
+}
diff --git a/src/src/app/src/main/java/net/micode/notes/ui/GestureSetting.java b/src/src/app/src/main/java/net/micode/notes/ui/GestureSetting.java
new file mode 100644
index 0000000..683d362
--- /dev/null
+++ b/src/src/app/src/main/java/net/micode/notes/ui/GestureSetting.java
@@ -0,0 +1,104 @@
+package net.micode.notes.ui;
+
+import android.Manifest;
+import android.app.Activity;
+import android.app.AlertDialog;
+import android.content.DialogInterface;
+import android.content.SharedPreferences;
+import android.gesture.Gesture;
+import android.gesture.GestureLibraries;
+import android.gesture.GestureLibrary;
+import android.gesture.GestureOverlayView;
+import android.graphics.Bitmap;
+import android.graphics.Color;
+import android.os.Bundle;
+import android.view.View;
+import android.widget.ImageView;
+import android.widget.RadioButton;
+import android.widget.RadioGroup;
+import android.widget.Toast;
+
+import androidx.core.app.ActivityCompat;
+
+import net.micode.notes.R;
+
+public class GestureSetting extends Activity {
+ //单选按钮的按钮群
+ private RadioGroup radgroup;
+ //当前被选中的单选按钮
+ private RadioButton radbtn;
+ //绘制的手势
+ private GestureOverlayView gesture;
+ //用SharedPreferences来存储哪些功能已经被绑定
+ private SharedPreferences.Editor editor;
+ //用来保存的对话框
+ private View saveDialog;
+ @Override
+ protected void onCreate(Bundle savedInstanceState) {
+ super.onCreate(savedInstanceState);
+ //加载活动视图
+ setContentView(R.layout.gesture_setting);
+ //打开数据库编辑器
+ editor = getSharedPreferences("Gesture",MODE_PRIVATE).edit();
+ //返回NotesListActivity活动会用到
+ setResult(RESULT_OK);
+ ActivityCompat.requestPermissions(GestureSetting.this, new String[]{Manifest.permission.WRITE_EXTERNAL_STORAGE}, 1);//动态申请权限
+ //获取手势编辑组件后,设置相关参数
+ gesture = (GestureOverlayView) findViewById(R.id.gesture);
+ gesture.setGestureColor(Color.GREEN);
+ gesture.setGestureStrokeWidth(5);
+ gesture.addOnGesturePerformedListener(new GestureOverlayView.OnGesturePerformedListener() {
+ @Override
+ public void onGesturePerformed(GestureOverlayView gestureOverlayView, final Gesture gesture) {
+ saveDialog = getLayoutInflater().inflate(R.layout.dialog_save,null,false);
+ //添加视图
+ radgroup = (RadioGroup)saveDialog.findViewById(R.id.radioGroup);
+ //初始化当前选中的单选按钮,即CreateNewFolder
+ radbtn = (RadioButton)saveDialog.findViewById(R.id.CreateNewFolder);
+ //单选按钮变换监听器
+ radgroup.setOnCheckedChangeListener(new RadioGroup.OnCheckedChangeListener() {
+ @Override
+ public void onCheckedChanged(RadioGroup group, int checkedId) {
+ //改变当前选中的单选按钮
+ radbtn = (RadioButton) saveDialog.findViewById(checkedId);
+ Toast.makeText(getApplicationContext(), "按钮组值发生改变,你选了" + radbtn.getText(), Toast.LENGTH_SHORT).show();
+ }
+ });
+ //手势的图片
+ ImageView img_show = (ImageView) saveDialog.findViewById(R.id.img_show);
+ Bitmap bitmap = gesture.toBitmap(128,128,10,0xffff0000);
+ img_show.setImageBitmap(bitmap);
+ new AlertDialog.Builder(GestureSetting.this).setView(saveDialog)
+ .setPositiveButton("保存",new DialogInterface.OnClickListener()
+ {
+ @Override
+ public void onClick(DialogInterface dialogInterface, int i) {
+ //打开数据库,如果功能还未对应手势,则添加功能和手势的绑定
+ SharedPreferences pref = getSharedPreferences("Gesture",MODE_PRIVATE);
+ if(pref.getString(radbtn.getText().toString(),"False").equals("False")) {
+ editor.putString(radbtn.getText().toString(), "True");
+ editor.apply();
+ //获取文件对应的手势库
+ GestureLibrary gestureLib = GestureLibraries.fromFile("/mnt/sdcard/mygestures");
+ //添加手势
+ gestureLib.addGesture(radbtn.getText().toString(), gesture);
+ //储存手势
+ gestureLib.save();
+ }
+ else{//若功能已经绑定手势,则提醒即将覆盖旧的手势
+ editor.putString(radbtn.getText().toString(), "True");
+ editor.apply();
+ Toast.makeText(GestureSetting.this,"此操作已被设置手势,即将覆盖",Toast.LENGTH_LONG);
+ GestureLibrary gestureLib = GestureLibraries.fromFile("/mnt/sdcard/mygestures");
+ //移除旧的手势
+ gestureLib.removeEntry(radbtn.getText().toString());
+ //添加新的手势
+ gestureLib.addGesture(radbtn.getText().toString(), gesture);
+ gestureLib.save();
+ }
+ }
+ }).setNegativeButton("取消", null).show();
+ }
+ });
+ }
+}
\ No newline at end of file
diff --git a/src/src/app/src/main/java/net/micode/notes/ui/MyBoard.java b/src/src/app/src/main/java/net/micode/notes/ui/MyBoard.java
new file mode 100644
index 0000000..880ab05
--- /dev/null
+++ b/src/src/app/src/main/java/net/micode/notes/ui/MyBoard.java
@@ -0,0 +1,124 @@
+package net.micode.notes.ui;
+
+import java.io.File;
+import java.io.FileNotFoundException;
+import java.io.FileOutputStream;
+import net.micode.notes.R;
+
+import android.app.Activity;
+import android.content.Intent;
+import android.graphics.Bitmap;
+import android.graphics.BitmapFactory;
+import android.graphics.Canvas;
+import android.graphics.Color;
+import android.graphics.Matrix;
+import android.graphics.Paint;
+import android.os.Bundle;
+import android.os.Environment;
+import android.view.MotionEvent;
+import android.view.View;
+import android.widget.ImageView;
+import android.widget.Toast;
+//mine 127
+public class MyBoard extends Activity {
+ private ImageView imageView;
+ private Bitmap copyBitmap;
+ private Paint paint;
+ private Canvas canvas;
+ private float startX;
+ private float startY;
+ private int ColorBox[] = {Color.BLACK,Color.GRAY,Color.LTGRAY,Color.RED,Color.BLUE,Color.YELLOW,Color.CYAN,Color.MAGENTA};//颜色种类
+ private int ColorIndex = 0;//当前指向的颜色
+ private int SizeBox[] = {5,10,15,20,25};//字体大小
+ private int SizeIndex = 0;//当前指向的字体大小
+
+ @Override
+ protected void onCreate(Bundle savedInstanceState) {
+ super.onCreate(savedInstanceState);
+ setContentView(R.layout.myboard);
+
+ imageView = (ImageView) findViewById(R.id.iv_image);
+ //使用Bitmap工厂把画板背景图片加载进来
+ Bitmap bitmap = BitmapFactory.decodeResource(getResources(), R.drawable.huaban);
+ //创建一个空的图片,宽度和高度 还有信息跟原图片一样
+ copyBitmap = Bitmap.createBitmap(bitmap.getWidth(), bitmap.getHeight(), bitmap.getConfig());
+ //创建画笔
+ paint = new Paint();
+ paint.setStrokeWidth(SizeBox[SizeIndex]);
+ paint.setColor(ColorBox[0]);
+ //创建一个画布
+ canvas = new Canvas(copyBitmap);
+ //开始画画
+ canvas.drawBitmap(bitmap, new Matrix(), paint);
+ imageView.setImageBitmap(copyBitmap);//用copyBitmap覆盖
+
+ //图片的触摸事件(即拖动画笔画画)
+ imageView.setOnTouchListener(new View.OnTouchListener() {
+ @Override
+ public boolean onTouch(View v, MotionEvent event) {
+ //获取动作的事件
+ int action = event.getAction();
+ switch (action) {
+ case MotionEvent.ACTION_DOWN:
+ //按下事件
+ startX = event.getX();
+ startY = event.getY();
+ break;
+ case MotionEvent.ACTION_MOVE:
+ //滑动事件
+ float x = event.getX();
+ float y = event.getY();
+ //在画布上画直线,不能画点,滑动事件获得的坐标不是连续的
+ canvas.drawLine(startX, startY, x, y, paint);
+ //更新图片
+ imageView.setImageBitmap(copyBitmap);
+ startX = x;
+ startY = y;
+ break;
+ case MotionEvent.ACTION_UP:
+ //抬起事件
+ float upX = event.getX();
+ float upY = event.getY();
+ break;
+ }
+ //必须设置为true,否则只执行按下事件
+ return true;
+ }
+ });
+
+ }
+ public void ClearBoard(View View){//清空画板,方法是重新创建一个画布
+ Bitmap bitmap = BitmapFactory.decodeResource(getResources(), R.drawable.huaban);
+ Paint paint = new Paint();
+ canvas.drawBitmap(bitmap, new Matrix(), paint);
+ }
+ //修改画笔的颜色
+ public void changeColor(View view) {
+ paint.setColor(ColorBox[(++ColorIndex)%8]);
+ }
+
+ //设置画笔的粗细
+ public void bold(View view) {
+ paint.setStrokeWidth(SizeBox[((++SizeIndex)%5)]);
+ }
+
+ //保存图片
+ public void save(View view) {
+ //创建一个图片的文件
+ String draw_path = Environment.getExternalStorageDirectory()+"/"+System.currentTimeMillis() + ".png";
+ File file = new File(draw_path);
+ FileOutputStream straeam;
+ try {
+ straeam = new FileOutputStream(file);
+ //生成图片,compress方法参数①为图片的类型,参数②为图片质量,参数③为文件输出流
+ copyBitmap.compress(Bitmap.CompressFormat.PNG, 100, straeam);
+ Toast.makeText(this, "保存成功", Toast.LENGTH_SHORT).show();
+ } catch (FileNotFoundException e) {
+ e.printStackTrace();
+ }
+ Intent intent1=new Intent();//构造Intent,用于传递数据
+ intent1.putExtra("draw path",draw_path);//传递储存的路径
+ setResult(RESULT_OK,intent1);//专门向上一个活动传递数据的
+ finish();//退出活动
+ }
+}
\ No newline at end of file
diff --git a/src/src/app/src/main/java/net/micode/notes/ui/NoteEditActivity.java b/src/src/app/src/main/java/net/micode/notes/ui/NoteEditActivity.java
new file mode 100644
index 0000000..b175a46
--- /dev/null
+++ b/src/src/app/src/main/java/net/micode/notes/ui/NoteEditActivity.java
@@ -0,0 +1,1272 @@
+/*
+ * Copyright (c) 2010-2011, The MiCode Open Source Community (www.micode.net)
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+
+package net.micode.notes.ui;
+
+import java.io.*;
+import java.util.Calendar;
+
+import android.Manifest;
+import android.content.pm.PackageManager;
+import android.graphics.Bitmap;
+import android.graphics.BitmapFactory;
+import android.location.Location;
+import android.location.LocationManager;
+import android.net.Uri;
+import android.os.Build;
+import android.os.Environment;
+import android.provider.MediaStore;
+import android.app.Activity;
+import android.app.AlarmManager;
+import android.app.AlertDialog;
+import android.app.Dialog;
+import android.app.PendingIntent;
+import android.app.SearchManager;
+import android.appwidget.AppWidgetManager;
+import android.content.ContentUris;
+import android.content.Context;
+import android.content.DialogInterface;
+import android.content.Intent;
+import android.content.SharedPreferences;
+import android.database.Cursor;
+import android.graphics.Paint;
+import android.os.Bundle;
+import android.preference.PreferenceManager;
+import android.text.Editable;
+import android.text.Spannable;
+import android.text.SpannableString;
+import android.text.Spanned;
+import android.text.TextUtils;
+import android.text.TextWatcher;
+import android.text.format.DateUtils;
+import android.text.style.BackgroundColorSpan;
+import android.text.style.ImageSpan;
+import android.util.Log;
+import android.view.LayoutInflater;
+import android.view.Menu;
+import android.view.MenuItem;
+import android.view.MotionEvent;
+import android.view.View;
+import android.view.View.OnClickListener;
+import android.view.WindowManager;
+import android.view.inputmethod.InputMethodManager;
+import android.widget.Button;
+import android.widget.CheckBox;
+import android.widget.CompoundButton;
+import android.widget.CompoundButton.OnCheckedChangeListener;
+import android.widget.EditText;
+import android.widget.ImageView;
+import android.widget.LinearLayout;
+import android.widget.TextView;
+import android.widget.Toast;
+
+import androidx.annotation.RequiresApi;
+import androidx.core.app.ActivityCompat;
+import androidx.core.content.ContextCompat;
+
+import net.micode.notes.R;
+import net.micode.notes.data.Notes;
+import net.micode.notes.data.Notes.TextNote;
+import net.micode.notes.data.NotesDatabaseHelper;
+import net.micode.notes.model.WorkingNote;
+import net.micode.notes.model.WorkingNote.NoteSettingChangedListener;
+import net.micode.notes.tool.DataUtils;
+import net.micode.notes.tool.ImageUtils;
+import net.micode.notes.tool.ResourceParser;
+import net.micode.notes.tool.ResourceParser.TextAppearanceResources;
+import net.micode.notes.tool.ScreenUtils;
+import net.micode.notes.ui.DateTimePickerDialog.OnDateTimeSetListener;
+import net.micode.notes.ui.NoteEditText.OnTextViewChangeListener;
+import net.micode.notes.widget.NoteWidgetProvider_2x;
+import net.micode.notes.widget.NoteWidgetProvider_4x;
+
+import java.io.BufferedReader;
+import java.io.File;
+import java.io.FileNotFoundException;
+import java.io.FileOutputStream;
+import java.io.IOException;
+import java.io.InputStream;
+import java.io.InputStreamReader;
+import java.util.HashMap;
+import java.util.HashSet;
+import java.util.Map;
+import java.util.regex.Matcher;
+import java.util.regex.Pattern;
+import java.util.Date;
+import java.sql.Timestamp;
+import java.util.TimeZone;
+
+public class NoteEditActivity extends Activity
+ implements OnClickListener, NoteSettingChangedListener, OnTextViewChangeListener {
+
+ private class HeadViewHolder {
+ public TextView tvModified;
+
+ public ImageView ivAlertIcon;
+
+ public TextView tvAlertDate;
+
+ public ImageView ibSetBgColor;
+ }
+
+ private static final Map sBgSelectorBtnsMap = new HashMap();
+
+ static {
+ sBgSelectorBtnsMap.put(R.id.iv_bg_yellow, ResourceParser.YELLOW);
+ sBgSelectorBtnsMap.put(R.id.iv_bg_red, ResourceParser.RED);
+ sBgSelectorBtnsMap.put(R.id.iv_bg_blue, ResourceParser.BLUE);
+ sBgSelectorBtnsMap.put(R.id.iv_bg_green, ResourceParser.GREEN);
+ sBgSelectorBtnsMap.put(R.id.iv_bg_white, ResourceParser.WHITE);
+ }
+
+ private static final Map sBgSelectorSelectionMap = new HashMap();
+
+ static {
+ sBgSelectorSelectionMap.put(ResourceParser.YELLOW, R.id.iv_bg_yellow_select);
+ sBgSelectorSelectionMap.put(ResourceParser.RED, R.id.iv_bg_red_select);
+ sBgSelectorSelectionMap.put(ResourceParser.BLUE, R.id.iv_bg_blue_select);
+ sBgSelectorSelectionMap.put(ResourceParser.GREEN, R.id.iv_bg_green_select);
+ sBgSelectorSelectionMap.put(ResourceParser.WHITE, R.id.iv_bg_white_select);
+ }
+
+ private static final Map sFontSizeBtnsMap = new HashMap();
+
+ static {
+ sFontSizeBtnsMap.put(R.id.ll_font_large, ResourceParser.TEXT_LARGE);
+ sFontSizeBtnsMap.put(R.id.ll_font_small, ResourceParser.TEXT_SMALL);
+ sFontSizeBtnsMap.put(R.id.ll_font_normal, ResourceParser.TEXT_MEDIUM);
+ sFontSizeBtnsMap.put(R.id.ll_font_super, ResourceParser.TEXT_SUPER);
+ }
+
+ private static final Map sFontSelectorSelectionMap = new HashMap();
+
+ static {
+ sFontSelectorSelectionMap.put(ResourceParser.TEXT_LARGE, R.id.iv_large_select);
+ sFontSelectorSelectionMap.put(ResourceParser.TEXT_SMALL, R.id.iv_small_select);
+ sFontSelectorSelectionMap.put(ResourceParser.TEXT_MEDIUM, R.id.iv_medium_select);
+ sFontSelectorSelectionMap.put(ResourceParser.TEXT_SUPER, R.id.iv_super_select);
+ }
+
+ public long mId;
+
+ private static final String TAG = "NoteEditActivity";
+
+ private HeadViewHolder mNoteHeaderHolder;
+
+ private View mHeadViewPanel;
+
+ private View mNoteBgColorSelector;
+
+ private View mFontSizeSelector;
+
+ private EditText mNoteEditor;
+
+ private View mNoteEditorPanel;
+
+ private WorkingNote mWorkingNote;
+
+ private SharedPreferences mSharedPrefs;
+
+ private int mFontSizeId;
+
+ private static final String PREFERENCE_FONT_SIZE = "pref_font_size";
+
+ private static final int SHORTCUT_ICON_TITLE_MAX_LEN = 10;
+
+ public static final String TAG_CHECKED = String.valueOf('\u221A');// 打勾的符号
+ public static final String TAG_UNCHECKED = String.valueOf('\u25A1');// 方框的符号
+
+ private LinearLayout mEditTextList;
+
+ private String mUserQuery;
+
+ private Pattern mPattern;
+
+ private TextView textView;
+ // mine 1
+ private String pathTakingPhoto;
+
+ @Override
+ protected void onCreate(Bundle savedInstanceState) {
+ super.onCreate(savedInstanceState);
+ this.setContentView(R.layout.note_edit);
+ if (savedInstanceState == null && !initActivityState(getIntent())) {
+ finish();
+ return;
+ }
+ initResources();
+ count();
+ }
+
+ private String Textchange(String oriText) {
+ StringBuffer stringBuffer = new StringBuffer(oriText);
+ int Flag1 = -1;
+ int Flag2 = -1;
+ do {// 不计入表示图片的字符
+ Flag1 = stringBuffer.indexOf("");
+ if (Flag1 != -1 && Flag2 != -1) {
+ stringBuffer = stringBuffer.replace(Flag1, Flag2 + 1, "");
+ }
+ } while (Flag1 != -1 && Flag2 != -1);
+
+ do {// 不计入换行字符
+ Flag1 = stringBuffer.indexOf("\n");
+
+ if (Flag1 != -1) {
+ stringBuffer = stringBuffer.replace(Flag1, Flag1 + 1, "");
+ }
+ } while (Flag1 != -1);
+ do {// 不计入空格字符
+ Flag1 = stringBuffer.indexOf(" ");
+
+ if (Flag1 != -1) {
+ stringBuffer = stringBuffer.replace(Flag1, Flag1 + 1, "");
+ }
+ } while (Flag1 != -1);
+ return stringBuffer.toString();
+ }
+
+ private void count() {// 图片删除有bug
+ mNoteEditor.addTextChangedListener(new TextWatcher() {
+ int currentLength = 0;
+
+ @Override
+ public void beforeTextChanged(CharSequence s, int start, int count, int after) {
+ textView.setText("");
+ }
+
+ @Override
+ public void onTextChanged(CharSequence s, int start, int before, int count) {
+ currentLength = Textchange(mNoteEditor.getText().toString()).length();
+ }
+
+ @Override
+ public void afterTextChanged(Editable s) {
+ textView.setText("");
+ }
+ });
+ }
+
+ // mine 41
+ @RequiresApi(api = Build.VERSION_CODES.KITKAT)
+ private void initEditText() {
+ InputStream in = null;
+ switch (getIntent().getIntExtra("open_mode", 0)) {
+ case 1://
+ Calendar calendar = Calendar.getInstance();
+ Calendar cal = cal = Calendar.getInstance();
+ cal.setTimeZone(TimeZone.getTimeZone("GMT+8:00"));
+ String year = String.valueOf(cal.get(Calendar.YEAR));
+ String month = String.valueOf(cal.get(Calendar.MONTH) + 1);
+ String day = String.valueOf(cal.get(Calendar.DATE));
+ String hour = String.valueOf(cal.get(Calendar.HOUR) + 12);
+ String minute = String.valueOf(cal.get(Calendar.MINUTE));
+ String str = year + "年" + month + "月" + day + "日" + hour + "时" + minute + "分\n";
+ in = new ByteArrayInputStream(str.getBytes());
+ break;
+ case 2://
+ String serviceString = Context.LOCATION_SERVICE;// 获取的是位置服务
+ LocationManager locationManager = (LocationManager) getSystemService(serviceString);// 调用getSystemService()方法来获取LocationManager对象
+ String provider = LocationManager.GPS_PROVIDER;// 指定LocationManager的定位方法
+
+ Location loc;// 调用getLastKnownLocation()方法获取当前的位置信息
+ if (ContextCompat.checkSelfPermission(this,
+ android.Manifest.permission.ACCESS_FINE_LOCATION) == PackageManager.PERMISSION_GRANTED
+ || ContextCompat.checkSelfPermission(this,
+ android.Manifest.permission.ACCESS_COARSE_LOCATION) == PackageManager.PERMISSION_GRANTED) {
+ loc = locationManager.getLastKnownLocation(provider);
+ double lat = loc.getLatitude();// 获取纬度
+ double lng = loc.getLongitude();// 获取经度
+ String str2 = String.valueOf(lat) + String.valueOf(lng);
+ in = new ByteArrayInputStream(str2.getBytes());
+ }
+ break;
+ default:// 创建普通便签
+ break;
+ }
+
+ // 仿照setAppInfoFromRawRes方法,从资源里添加文本
+ if (in == null)
+ return;
+ Editable edit = mNoteEditor.getText();
+ StringBuilder sb = new StringBuilder();// 代表一个字符序列可变的字符串
+ try (InputStreamReader isr = new InputStreamReader(in); BufferedReader br = new BufferedReader(isr);) {
+ // 使用指定的字符集读取字节并将它们解码为字符
+ // 缓冲区流读入
+ char[] buf = new char[1024];
+ int len = 0;
+ while ((len = br.read(buf)) > 0) {// read读取一个字符,若读取到末尾则返回-1,这里是加载到buf中
+ sb.append(buf, 0, len);// 从buf里0开始的len长度的字符串加载到sb后
+ }
+ } catch (IOException e) {
+ e.printStackTrace();
+ }
+ edit.append(sb.toString());
+ mNoteEditor.setText(edit);
+ if (in != null) {
+ try {
+ in.close();
+ } catch (IOException e) {
+ Log.e(TAG, "initEditText " + e.toString());
+ }
+ }
+ }
+
+ // mine 3
+ @RequiresApi(api = Build.VERSION_CODES.KITKAT)
+ @Override
+ protected void onResume() {
+ super.onResume();
+ initNoteScreen();
+ initEditText();// 初始化便签模板
+ initImage();// 初始化图片
+ }
+
+ @Override
+ protected void onPause() {
+ super.onPause();
+ if (saveNote()) {
+ Log.d(TAG, "Note data was saved with length:" + mWorkingNote.getContent().length());
+ }
+ clearSettingState();
+ }
+
+ /**
+ * Current activity may be killed when the memory is low. Once it is killed, for
+ * another time user load this activity, we should restore the former state
+ */
+ @Override
+ protected void onRestoreInstanceState(Bundle savedInstanceState) {
+ super.onRestoreInstanceState(savedInstanceState);
+ if (savedInstanceState != null && savedInstanceState.containsKey(Intent.EXTRA_UID)) {
+ Intent intent = new Intent(Intent.ACTION_VIEW);
+ intent.putExtra(Intent.EXTRA_UID, savedInstanceState.getLong(Intent.EXTRA_UID));
+ if (!initActivityState(intent)) {
+ finish();
+ return;
+ }
+ Log.d(TAG, "Restoring from killed activity");
+ }
+ }
+
+ private boolean initActivityState(Intent intent) {
+ /**
+ * If the user specified the {@link Intent#ACTION_VIEW} but not provided with
+ * id, then jump to the NotesListActivity
+ */
+ mWorkingNote = null;
+ if (TextUtils.equals(Intent.ACTION_VIEW, intent.getAction())) {
+ mId = intent.getLongExtra(Intent.EXTRA_UID, 0);
+ mUserQuery = "";
+
+ /**
+ * Starting from the searched result
+ */
+ if (intent.hasExtra(SearchManager.EXTRA_DATA_KEY)) {
+ mId = Long.parseLong(intent.getStringExtra(SearchManager.EXTRA_DATA_KEY));
+ mUserQuery = intent.getStringExtra(SearchManager.USER_QUERY);
+ }
+
+ if (!DataUtils.visibleInNoteDatabase(getContentResolver(), mId, Notes.TYPE_NOTE)) {
+ Intent jump = new Intent(this, NotesListActivity.class);
+ startActivity(jump);
+ showToast(R.string.error_note_not_exist);
+ finish();
+ return false;
+ } else {
+ mWorkingNote = WorkingNote.load(this, mId);
+ if (mWorkingNote == null) {
+ Log.e(TAG, "load note failed with note id" + mId);
+ finish();
+ return false;
+ }
+ }
+ getWindow().setSoftInputMode(WindowManager.LayoutParams.SOFT_INPUT_STATE_HIDDEN
+ | WindowManager.LayoutParams.SOFT_INPUT_ADJUST_RESIZE);
+ } else if (TextUtils.equals(Intent.ACTION_INSERT_OR_EDIT, intent.getAction())) {
+ // New note
+ long folderId = intent.getLongExtra(Notes.INTENT_EXTRA_FOLDER_ID, 0);
+ int widgetId = intent.getIntExtra(Notes.INTENT_EXTRA_WIDGET_ID, AppWidgetManager.INVALID_APPWIDGET_ID);
+ int widgetType = intent.getIntExtra(Notes.INTENT_EXTRA_WIDGET_TYPE, Notes.TYPE_WIDGET_INVALIDE);
+ int bgResId = intent.getIntExtra(Notes.INTENT_EXTRA_BACKGROUND_ID, ResourceParser.getDefaultBgId(this));
+
+ // Parse call-record note
+ String phoneNumber = intent.getStringExtra(Intent.EXTRA_PHONE_NUMBER);
+ long callDate = intent.getLongExtra(Notes.INTENT_EXTRA_CALL_DATE, 0);
+ if (callDate != 0 && phoneNumber != null) {
+ if (TextUtils.isEmpty(phoneNumber)) {
+ Log.w(TAG, "The call record number is null");
+ }
+ long noteId = 0;
+ if ((noteId = DataUtils.getNoteIdByPhoneNumberAndCallDate(getContentResolver(), phoneNumber,
+ callDate)) > 0) {
+ mWorkingNote = WorkingNote.load(this, noteId);
+ if (mWorkingNote == null) {
+ Log.e(TAG, "load call note failed with note id" + noteId);
+ finish();
+ return false;
+ }
+ } else {
+ mWorkingNote = WorkingNote.createEmptyNote(this, folderId, widgetId, widgetType, bgResId);
+ mWorkingNote.convertToCallNote(phoneNumber, callDate);
+ }
+ } else {
+ mWorkingNote = WorkingNote.createEmptyNote(this, folderId, widgetId, widgetType, bgResId);
+ }
+
+ getWindow().setSoftInputMode(WindowManager.LayoutParams.SOFT_INPUT_ADJUST_RESIZE
+ | WindowManager.LayoutParams.SOFT_INPUT_STATE_VISIBLE);
+ } else if (TextUtils.equals(Intent.ACTION_SEARCH, intent.getAction())) // 点击搜索按钮响应
+ {
+ String querystring = intent.getStringExtra(SearchManager.QUERY); // 获取搜索框内的字符串
+ NotesDatabaseHelper dbhelper = new NotesDatabaseHelper(this);
+ dbhelper.dosearch(querystring);
+ finish();
+ return false;
+ } else {
+ Log.e(TAG, "Intent not specified action, should not support");
+ finish();
+ return false;
+ }
+ mWorkingNote.setOnSettingStatusChangedListener(this);
+ return true;
+ }
+
+ private void initNoteScreen() {
+ mNoteEditor.setTextAppearance(this, TextAppearanceResources.getTexAppearanceResource(mFontSizeId));
+ if (mWorkingNote.getCheckListMode() == TextNote.MODE_CHECK_LIST) {
+ switchToListMode(mWorkingNote.getContent());
+ } else {
+ mNoteEditor.setText(getHighlightQueryResult(mWorkingNote.getContent(), mUserQuery));
+ mNoteEditor.setSelection(mNoteEditor.getText().length());
+ }
+ for (Integer id : sBgSelectorSelectionMap.keySet()) {
+ findViewById(sBgSelectorSelectionMap.get(id)).setVisibility(View.GONE);
+ }
+ mHeadViewPanel.setBackgroundResource(mWorkingNote.getTitleBgResId());
+ mNoteEditorPanel.setBackgroundResource(mWorkingNote.getBgColorResId());
+
+ mNoteHeaderHolder.tvModified
+ .setText(DateUtils.formatDateTime(this, mWorkingNote.getModifiedDate(), DateUtils.FORMAT_SHOW_DATE
+ | DateUtils.FORMAT_NUMERIC_DATE | DateUtils.FORMAT_SHOW_TIME | DateUtils.FORMAT_SHOW_YEAR));
+
+ /**
+ * TODO: Add the menu for setting alert. Currently disable it because the
+ * DateTimePicker is not ready
+ */
+ showAlertHeader();
+ }
+
+ private void showAlertHeader() {
+ if (mWorkingNote.hasClockAlert()) {
+ long time = System.currentTimeMillis();
+ if (time > mWorkingNote.getAlertDate()) {
+ mNoteHeaderHolder.tvAlertDate.setText(R.string.note_alert_expired);
+ } else {
+ mNoteHeaderHolder.tvAlertDate.setText(DateUtils.getRelativeTimeSpanString(mWorkingNote.getAlertDate(),
+ time, DateUtils.MINUTE_IN_MILLIS));
+ }
+ mNoteHeaderHolder.tvAlertDate.setVisibility(View.VISIBLE);
+ mNoteHeaderHolder.ivAlertIcon.setVisibility(View.VISIBLE);
+ } else {
+ mNoteHeaderHolder.tvAlertDate.setVisibility(View.GONE);
+ mNoteHeaderHolder.ivAlertIcon.setVisibility(View.GONE);
+ }
+ }
+
+ @Override
+ protected void onNewIntent(Intent intent) {
+ super.onNewIntent(intent);
+ initActivityState(intent);
+ }
+
+ @Override
+ protected void onSaveInstanceState(Bundle outState) {
+ super.onSaveInstanceState(outState);
+ /**
+ * For new note without note id, we should firstly save it to generate a id. If
+ * the editing note is not worth saving, there is no id which is equivalent to
+ * create new note
+ */
+ if (!mWorkingNote.existInDatabase()) {
+ saveNote();
+ }
+ outState.putLong(Intent.EXTRA_UID, mWorkingNote.getNoteId());
+ Log.d(TAG, "Save working note id: " + mWorkingNote.getNoteId() + " onSaveInstanceState");
+ }
+
+ @Override
+ public boolean dispatchTouchEvent(MotionEvent ev) {
+ if (mNoteBgColorSelector.getVisibility() == View.VISIBLE && !inRangeOfView(mNoteBgColorSelector, ev)) {
+ mNoteBgColorSelector.setVisibility(View.GONE);
+ return true;
+ }
+
+ if (mFontSizeSelector.getVisibility() == View.VISIBLE && !inRangeOfView(mFontSizeSelector, ev)) {
+ mFontSizeSelector.setVisibility(View.GONE);
+ return true;
+ }
+ return super.dispatchTouchEvent(ev);
+ }
+
+ private boolean inRangeOfView(View view, MotionEvent ev) {
+ int[] location = new int[2];
+ view.getLocationOnScreen(location);
+ int x = location[0];
+ int y = location[1];
+ if (ev.getX() < x || ev.getX() > (x + view.getWidth()) || ev.getY() < y || ev.getY() > (y + view.getHeight())) {
+ return false;
+ }
+ return true;
+ }
+
+ private void initResources() {
+ mHeadViewPanel = findViewById(R.id.note_title);
+ mNoteHeaderHolder = new HeadViewHolder();
+ mNoteHeaderHolder.tvModified = (TextView) findViewById(R.id.tv_modified_date);
+ mNoteHeaderHolder.ivAlertIcon = (ImageView) findViewById(R.id.iv_alert_icon);
+ mNoteHeaderHolder.tvAlertDate = (TextView) findViewById(R.id.tv_alert_date);
+ mNoteHeaderHolder.ibSetBgColor = (ImageView) findViewById(R.id.btn_set_bg_color);
+ mNoteHeaderHolder.ibSetBgColor.setOnClickListener(this);
+ mNoteEditor = (EditText) findViewById(R.id.note_edit_view);
+ mNoteEditorPanel = findViewById(R.id.sv_note_edit);
+ mNoteBgColorSelector = findViewById(R.id.note_bg_color_selector);
+
+ textView = (TextView) findViewById(R.id.text_num);// mine
+ for (int id : sBgSelectorBtnsMap.keySet()) {
+ ImageView iv = (ImageView) findViewById(id);
+ iv.setOnClickListener(this);
+ }
+
+ mFontSizeSelector = findViewById(R.id.font_size_selector);
+ for (int id : sFontSizeBtnsMap.keySet()) {
+ View view = findViewById(id);
+ view.setOnClickListener(this);
+ }
+ ;
+ mSharedPrefs = PreferenceManager.getDefaultSharedPreferences(this);
+ mFontSizeId = mSharedPrefs.getInt(PREFERENCE_FONT_SIZE, ResourceParser.BG_DEFAULT_FONT_SIZE);
+
+ /**
+ * HACKME: Fix bug of store the resource id in shared preference. The id may
+ * larger than the length of resources, in this case, return the
+ * {@link ResourceParser#BG_DEFAULT_FONT_SIZE}
+ */
+ if (mFontSizeId >= TextAppearanceResources.getResourcesSize()) {
+ mFontSizeId = ResourceParser.BG_DEFAULT_FONT_SIZE;
+ }
+ mEditTextList = (LinearLayout) findViewById(R.id.note_edit_list);
+ }
+
+ private void updateWidget() {
+ Intent intent = new Intent(AppWidgetManager.ACTION_APPWIDGET_UPDATE);
+ if (mWorkingNote.getWidgetType() == Notes.TYPE_WIDGET_2X) {
+ intent.setClass(this, NoteWidgetProvider_2x.class);
+ } else if (mWorkingNote.getWidgetType() == Notes.TYPE_WIDGET_4X) {
+ intent.setClass(this, NoteWidgetProvider_4x.class);
+ } else {
+ Log.e(TAG, "Unspported widget type");
+ return;
+ }
+
+ intent.putExtra(AppWidgetManager.EXTRA_APPWIDGET_IDS, new int[] { mWorkingNote.getWidgetId() });
+ sendBroadcast(intent);
+ setResult(RESULT_OK, intent);
+ }
+
+ public void onClick(View v) {
+ int id = v.getId();
+ if (id == R.id.btn_set_bg_color) {
+ mNoteBgColorSelector.setVisibility(View.VISIBLE);
+ findViewById(sBgSelectorSelectionMap.get(mWorkingNote.getBgColorId())).setVisibility(View.VISIBLE);
+ } else if (sBgSelectorBtnsMap.containsKey(id)) {
+ findViewById(sBgSelectorSelectionMap.get(mWorkingNote.getBgColorId())).setVisibility(View.GONE);
+ mWorkingNote.setBgColorId(sBgSelectorBtnsMap.get(id));
+ mNoteBgColorSelector.setVisibility(View.GONE);
+ } else if (sFontSizeBtnsMap.containsKey(id)) {
+ findViewById(sFontSelectorSelectionMap.get(mFontSizeId)).setVisibility(View.GONE);
+ mFontSizeId = sFontSizeBtnsMap.get(id);
+ mSharedPrefs.edit().putInt(PREFERENCE_FONT_SIZE, mFontSizeId).commit();
+ findViewById(sFontSelectorSelectionMap.get(mFontSizeId)).setVisibility(View.VISIBLE);
+ if (mWorkingNote.getCheckListMode() == TextNote.MODE_CHECK_LIST) {
+ getWorkingText();
+ switchToListMode(mWorkingNote.getContent());
+ } else {
+ mNoteEditor.setTextAppearance(this, TextAppearanceResources.getTexAppearanceResource(mFontSizeId));
+ }
+ mFontSizeSelector.setVisibility(View.GONE);
+ }
+ }
+
+ @Override
+ public void onBackPressed() {
+ if (clearSettingState()) {
+ return;
+ }
+ saveNote();
+ super.onBackPressed();
+ }
+
+ private boolean clearSettingState() {// 可见首先执行clearSettingState(),
+ // 它的作用就是判断当前是不是弹出了背景选择框和字体大小选择框,
+ // 如果是就先关闭它们;如果不是就会保存当前便签并退出当前Activity。
+ if (mNoteBgColorSelector.getVisibility() == View.VISIBLE) {
+ mNoteBgColorSelector.setVisibility(View.GONE);
+ return true;
+ } else if (mFontSizeSelector.getVisibility() == View.VISIBLE) {
+ mFontSizeSelector.setVisibility(View.GONE);
+ return true;
+ }
+ return false;
+ }
+
+ public void onBackgroundColorChanged() {
+ findViewById(sBgSelectorSelectionMap.get(mWorkingNote.getBgColorId())).setVisibility(View.VISIBLE);
+ mNoteEditorPanel.setBackgroundResource(mWorkingNote.getBgColorResId());
+ mHeadViewPanel.setBackgroundResource(mWorkingNote.getTitleBgResId());
+ }
+
+ @Override
+ public boolean onPrepareOptionsMenu(Menu menu) {// 准备菜单
+ if (isFinishing()) {
+ return true;
+ }
+ clearSettingState();
+ menu.clear();
+ if (mWorkingNote.getFolderId() == Notes.ID_CALL_RECORD_FOLDER) {
+ getMenuInflater().inflate(R.menu.call_note_edit, menu);
+ } else {
+ getMenuInflater().inflate(R.menu.note_edit, menu);
+ }
+ if (mWorkingNote.getCheckListMode() == TextNote.MODE_CHECK_LIST) {
+ menu.findItem(R.id.menu_list_mode).setTitle(R.string.menu_normal_mode);
+ } else {
+ menu.findItem(R.id.menu_list_mode).setTitle(R.string.menu_list_mode);
+ }
+ if (mWorkingNote.hasClockAlert()) {
+ menu.findItem(R.id.menu_alert).setVisible(false);
+ } else {
+ menu.findItem(R.id.menu_delete_remind).setVisible(false);
+ }
+ return true;
+ }
+
+ @Override
+ public boolean onOptionsItemSelected(MenuItem item) {
+ switch (item.getItemId()) {// mine 18
+ case R.id.menu_draw:// 打开画板
+ startDraw();
+ break;
+ case R.id.menu_camera:// 插入图片
+ callGallery();
+ break;
+ case R.id.menu_new_note:
+ createNewNote();
+ break;
+ case R.id.menu_delete:
+ AlertDialog.Builder builder = new AlertDialog.Builder(this);
+ builder.setTitle(getString(R.string.alert_title_delete));
+ builder.setIcon(android.R.drawable.ic_dialog_alert);
+ builder.setMessage(getString(R.string.alert_message_delete_note));
+ builder.setPositiveButton(android.R.string.ok, new DialogInterface.OnClickListener() {
+ public void onClick(DialogInterface dialog, int which) {
+ deleteCurrentNote();
+ finish();
+ }
+ });
+ builder.setNegativeButton(android.R.string.cancel, null);
+ builder.show();
+ break;
+ case R.id.menu_font_size:
+ mFontSizeSelector.setVisibility(View.VISIBLE);
+ findViewById(sFontSelectorSelectionMap.get(mFontSizeId)).setVisibility(View.VISIBLE);
+ break;
+ case R.id.menu_list_mode:
+ mWorkingNote.setCheckListMode(mWorkingNote.getCheckListMode() == 0 ? TextNote.MODE_CHECK_LIST : 0,
+ true);
+ break;
+ case R.id.menu_share:
+ getWorkingText();
+ sendTo(this, mWorkingNote.getContent());
+ break;
+ case R.id.menu_send_to_desktop:
+ sendToDesktop();
+ break;
+ case R.id.menu_alert:
+ setReminder();
+ break;
+ case R.id.menu_delete_remind:
+ mWorkingNote.setAlertDate(0, false);
+ break;
+ default:
+ break;
+ }
+ return true;
+ }
+
+ private void setReminder() {
+ DateTimePickerDialog d = new DateTimePickerDialog(this, System.currentTimeMillis());
+ d.setOnDateTimeSetListener(new OnDateTimeSetListener() {
+ public void OnDateTimeSet(AlertDialog dialog, long date) {
+ mWorkingNote.setAlertDate(date, true);
+ }
+ });
+ d.show();
+ }
+
+ /**
+ * Share note to apps that support {@link Intent#ACTION_SEND} action and
+ * {@text/plain} type
+ */
+ private void sendTo(Context context, String info) {
+ Intent intent = new Intent(Intent.ACTION_SEND);
+ intent.putExtra(Intent.EXTRA_TEXT, info);
+ intent.setType("text/plain");
+ context.startActivity(intent);
+ }
+
+ private void createNewNote() {// mine 1
+ // Firstly, save current editing notes
+ saveNote();
+
+ // For safety, start a new NoteEditActivity
+ finish();
+ Intent intent = new Intent(this, NoteEditActivity.class);
+ intent.setAction(Intent.ACTION_INSERT_OR_EDIT);
+ intent.putExtra("password", "");
+ intent.putExtra(Notes.INTENT_EXTRA_FOLDER_ID, mWorkingNote.getFolderId());
+ startActivity(intent);
+ }
+
+ private void deleteCurrentNote() {
+ if (mWorkingNote.existInDatabase()) {
+ HashSet ids = new HashSet();
+ long id = mWorkingNote.getNoteId();
+ if (id != Notes.ID_ROOT_FOLDER) {
+ ids.add(id);
+ } else {
+ Log.d(TAG, "Wrong note id, should not happen");
+ }
+ if (!isSyncMode()) {
+ if (!DataUtils.batchDeleteNotes(getContentResolver(), ids)) {
+ Log.e(TAG, "Delete Note error");
+ }
+ } else {
+ if (!DataUtils.batchMoveToFolder(getContentResolver(), ids, Notes.ID_TRASH_FOLER)) {
+ Log.e(TAG, "Move notes to trash folder error, should not happens");
+ }
+ }
+ }
+ mWorkingNote.markDeleted(true);
+ }
+
+ private boolean isSyncMode() {
+ return NotesPreferenceActivity.getSyncAccountName(this).trim().length() > 0;
+ }
+
+ public void onClockAlertChanged(long date, boolean set) {
+ /**
+ * User could set clock to an unsaved note, so before setting the alert clock,
+ * we should save the note first
+ */
+ if (!mWorkingNote.existInDatabase()) {
+ saveNote();
+ }
+ if (mWorkingNote.getNoteId() > 0) {
+ Intent intent = new Intent(this, AlarmReceiver.class);
+ intent.setData(ContentUris.withAppendedId(Notes.CONTENT_NOTE_URI, mWorkingNote.getNoteId()));
+ PendingIntent pendingIntent = PendingIntent.getBroadcast(this, 0, intent, 0);
+ AlarmManager alarmManager = ((AlarmManager) getSystemService(ALARM_SERVICE));
+ showAlertHeader();
+ if (!set) {
+ alarmManager.cancel(pendingIntent);
+ } else {
+ alarmManager.set(AlarmManager.RTC_WAKEUP, date, pendingIntent);
+ }
+ } else {
+ /**
+ * There is the condition that user has input nothing (the note is not worthy
+ * saving), we have no note id, remind the user that he should input something
+ */
+ Log.e(TAG, "Clock alert setting error");
+ showToast(R.string.error_note_empty_for_clock);
+ }
+ }
+
+ public void onWidgetChanged() {
+ updateWidget();
+ }
+
+ public void onEditTextDelete(int index, String text) {// wait
+ int childCount = mEditTextList.getChildCount();
+ if (childCount == 1) {
+ return;
+ }
+
+ for (int i = index + 1; i < childCount; i++) {
+ ((NoteEditText) mEditTextList.getChildAt(i).findViewById(R.id.et_edit_text)).setIndex(i - 1);
+ }
+
+ mEditTextList.removeViewAt(index);
+ NoteEditText edit = null;
+ if (index == 0) {
+ edit = (NoteEditText) mEditTextList.getChildAt(0).findViewById(R.id.et_edit_text);
+ } else {
+ edit = (NoteEditText) mEditTextList.getChildAt(index - 1).findViewById(R.id.et_edit_text);
+ }
+ int length = edit.length();
+ edit.append(text);
+ edit.requestFocus();
+ edit.setSelection(length);
+ }
+
+ public void onEditTextEnter(int index, String text) {
+ /**
+ * Should not happen, check for debug
+ */
+ if (index > mEditTextList.getChildCount()) {
+ Log.e(TAG, "Index out of mEditTextList boundrary, should not happen");
+ }
+
+ View view = getListItem(text, index);
+ mEditTextList.addView(view, index);
+ NoteEditText edit = (NoteEditText) view.findViewById(R.id.et_edit_text);
+ edit.requestFocus();
+ edit.setSelection(0);
+ for (int i = index + 1; i < mEditTextList.getChildCount(); i++) {
+ ((NoteEditText) mEditTextList.getChildAt(i).findViewById(R.id.et_edit_text)).setIndex(i);
+ }
+ }
+
+ private void switchToListMode(String text) {
+ mEditTextList.removeAllViews();
+ String[] items = text.split("\n");
+ int index = 0;
+ for (String item : items) {
+ if (!TextUtils.isEmpty(item)) {
+ mEditTextList.addView(getListItem(item, index));
+ index++;
+ }
+ }
+ mEditTextList.addView(getListItem("", index));
+ mEditTextList.getChildAt(index).findViewById(R.id.et_edit_text).requestFocus();
+
+ mNoteEditor.setVisibility(View.GONE);
+ mEditTextList.setVisibility(View.VISIBLE);
+ }
+
+ private Spannable getHighlightQueryResult(String fullText, String userQuery) {
+ SpannableString spannable = new SpannableString(fullText == null ? "" : fullText);
+ if (!TextUtils.isEmpty(userQuery)) {
+ mPattern = Pattern.compile(userQuery);
+ Matcher m = mPattern.matcher(fullText);
+ int start = 0;
+ while (m.find(start)) {
+ spannable.setSpan(new BackgroundColorSpan(this.getResources().getColor(R.color.user_query_highlight)),
+ m.start(), m.end(), Spannable.SPAN_INCLUSIVE_EXCLUSIVE);
+ start = m.end();
+ }
+ }
+ return spannable;
+ }
+
+ private View getListItem(String item, int index) {
+ View view = LayoutInflater.from(this).inflate(R.layout.note_edit_list_item, null);
+ final NoteEditText edit = (NoteEditText) view.findViewById(R.id.et_edit_text);
+ edit.setTextAppearance(this, TextAppearanceResources.getTexAppearanceResource(mFontSizeId));
+ CheckBox cb = ((CheckBox) view.findViewById(R.id.cb_edit_item));
+ cb.setOnCheckedChangeListener(new OnCheckedChangeListener() {
+ public void onCheckedChanged(CompoundButton buttonView, boolean isChecked) {
+ if (isChecked) {
+ edit.setPaintFlags(edit.getPaintFlags() | Paint.STRIKE_THRU_TEXT_FLAG);
+ } else {
+ edit.setPaintFlags(Paint.ANTI_ALIAS_FLAG | Paint.DEV_KERN_TEXT_FLAG);
+ }
+ }
+ });
+
+ if (item.startsWith(TAG_CHECKED)) {
+ cb.setChecked(true);
+ edit.setPaintFlags(edit.getPaintFlags() | Paint.STRIKE_THRU_TEXT_FLAG);
+ item = item.substring(TAG_CHECKED.length(), item.length()).trim();
+ } else if (item.startsWith(TAG_UNCHECKED)) {
+ cb.setChecked(false);
+ edit.setPaintFlags(Paint.ANTI_ALIAS_FLAG | Paint.DEV_KERN_TEXT_FLAG);
+ item = item.substring(TAG_UNCHECKED.length(), item.length()).trim();
+ }
+
+ edit.setOnTextViewChangeListener(this);
+ edit.setIndex(index);
+ edit.setText(getHighlightQueryResult(item, mUserQuery));
+ return view;
+ }
+
+ public void onTextChange(int index, boolean hasText) {
+ if (index >= mEditTextList.getChildCount()) {
+ Log.e(TAG, "Wrong index, should not happen");
+ return;
+ }
+ if (hasText) {
+ mEditTextList.getChildAt(index).findViewById(R.id.cb_edit_item).setVisibility(View.VISIBLE);
+ } else {
+ mEditTextList.getChildAt(index).findViewById(R.id.cb_edit_item).setVisibility(View.GONE);
+ }
+ }
+
+ public void onCheckListModeChanged(int oldMode, int newMode) {// 清单模式和普通模式
+ if (newMode == TextNote.MODE_CHECK_LIST) {
+ switchToListMode(mNoteEditor.getText().toString());
+ } else {
+ if (!getWorkingText()) {
+ mWorkingNote.setWorkingText(mWorkingNote.getContent().replace(TAG_UNCHECKED + " ", ""));// 无勾选的情况,就只要replace就行
+ }
+ mNoteEditor.setText(getHighlightQueryResult(mWorkingNote.getContent(), mUserQuery));
+ mEditTextList.setVisibility(View.GONE);
+ mNoteEditor.setVisibility(View.VISIBLE);
+ }
+ }
+
+ // 可以看首先对输入框内的文本进行非空判断,然后对这个CheckBox进行了判断是否选中,
+ // 但是最后都是在文本后加换行,然后把这个文本作为参数传给mWorkingNote的setWorkingText方法。
+ private boolean getWorkingText() {
+ boolean hasChecked = false;
+ if (mWorkingNote.getCheckListMode() == TextNote.MODE_CHECK_LIST) {// 判断是否为清单模式
+ StringBuilder sb = new StringBuilder();
+ for (int i = 0; i < mEditTextList.getChildCount(); i++) {// 判断便签里有几行
+ View view = mEditTextList.getChildAt(i);
+ NoteEditText edit = (NoteEditText) view.findViewById(R.id.et_edit_text);
+ if (!TextUtils.isEmpty(edit.getText())) {
+ if (((CheckBox) view.findViewById(R.id.cb_edit_item)).isChecked()) {
+ sb.append(TAG_CHECKED).append(" ").append(edit.getText()).append("\n");
+ hasChecked = true;
+ } else {
+ sb.append(TAG_UNCHECKED).append(" ").append(edit.getText()).append("\n");
+ }
+ }
+ }
+ mWorkingNote.setWorkingText(sb.toString());
+ } else {
+ mWorkingNote.setWorkingText(mNoteEditor.getText().toString());
+ }
+ return hasChecked;
+ }
+
+ private boolean saveNote() {// 把内容存到数据库里
+ getWorkingText();
+ boolean saved = mWorkingNote.saveNote();
+ if (saved) {
+ /**
+ * There are two modes from List view to edit view, open one note, create/edit a
+ * node. Opening node requires to the original position in the list when back
+ * from edit view, while creating a new node requires to the top of the list.
+ * This code {@link #RESULT_OK} is used to identify the create/edit state
+ */
+ setResult(RESULT_OK);
+ }
+ return saved;
+ }
+
+ private void sendToDesktop() {
+ /**
+ * Before send message to home, we should make sure that current editing note is
+ * exists in databases. So, for new note, firstly save it
+ */
+ if (!mWorkingNote.existInDatabase()) {
+ saveNote();
+ }
+
+ if (mWorkingNote.getNoteId() > 0) {
+ Intent sender = new Intent();
+ Intent shortcutIntent = new Intent(this, NoteEditActivity.class);
+ shortcutIntent.setAction(Intent.ACTION_VIEW);
+ shortcutIntent.putExtra(Intent.EXTRA_UID, mWorkingNote.getNoteId());
+ sender.putExtra(Intent.EXTRA_SHORTCUT_INTENT, shortcutIntent);
+ sender.putExtra(Intent.EXTRA_SHORTCUT_NAME, makeShortcutIconTitle(mWorkingNote.getContent()));
+ sender.putExtra(Intent.EXTRA_SHORTCUT_ICON_RESOURCE,
+ Intent.ShortcutIconResource.fromContext(this, R.drawable.icon_app));
+ sender.putExtra("duplicate", true);
+ sender.setAction("com.android.launcher.action.INSTALL_SHORTCUT");
+ showToast(R.string.info_note_enter_desktop);
+ sendBroadcast(sender);
+ } else {
+ /**
+ * There is the condition that user has input nothing (the note is not worthy
+ * saving), we have no note id, remind the user that he should input something
+ */
+ Log.e(TAG, "Send to desktop error");
+ showToast(R.string.error_note_empty_for_send_to_desktop);
+ }
+ }
+
+ private String makeShortcutIconTitle(String content) {
+ content = content.replace(TAG_CHECKED, "");
+ content = content.replace(TAG_UNCHECKED, "");
+ return content.length() > SHORTCUT_ICON_TITLE_MAX_LEN ? content.substring(0, SHORTCUT_ICON_TITLE_MAX_LEN)
+ : content;
+ }
+
+ private void showToast(int resId) {
+ showToast(resId, Toast.LENGTH_SHORT);
+ }
+
+ private void showToast(int resId, int duration) {
+ Toast.makeText(this, resId, duration).show();
+ }
+
+ // mine 261
+ private void showSoftInput() {// 显示软键盘
+ InputMethodManager inputMethodManager = (InputMethodManager) getSystemService(Context.INPUT_METHOD_SERVICE);// 获取方法的管理者对象
+ if (inputMethodManager != null) {
+ inputMethodManager.toggleSoftInput(InputMethodManager.SHOW_FORCED, 0);// 使软键盘显示,第二个参数hideFlags等于0
+ }
+ }
+
+ private void hideSoftInput(View view) {// 隐藏软键盘
+ InputMethodManager inputMethodManager = (InputMethodManager) getSystemService(Context.INPUT_METHOD_SERVICE);
+ inputMethodManager.hideSoftInputFromWindow(view.getWindowToken(), 0);// 隐藏软键盘
+ }
+
+ private void setPwd() {// wait
+ final AlertDialog.Builder builder = new AlertDialog.Builder(this);// 初始化对话框
+ View view = LayoutInflater.from(this).inflate(R.layout.dialog_pwd, null);// 加载对话框的布局文件
+ final EditText etPwd = (EditText) view.findViewById(R.id.set_private_pwd);// 初始化对话框里的文本对象
+ final EditText etHint = (EditText) view.findViewById(R.id.password_hint);// 初始化对话框里的文本对象
+ showSoftInput();// 显示软键盘
+ builder.setPositiveButton(android.R.string.ok, null);// 确定按钮
+ builder.setNegativeButton(android.R.string.cancel, new DialogInterface.OnClickListener() {
+ public void onClick(DialogInterface dialog, int which) {// 取消按钮
+ hideSoftInput(etPwd);// 隐藏软键盘
+ }
+ });
+ final Dialog dialog = builder.setView(view).show();// 显示出来
+ final Button positive = (Button) dialog.findViewById(android.R.id.button1);// 加载确定按钮布局文件
+ positive.setOnClickListener(new OnClickListener() {
+ public void onClick(View v) {// 设置确定按钮的接收器
+ hideSoftInput(etPwd);// 点击确定后收起软键盘
+ String Password = etPwd.getText().toString();
+ String Hint = etHint.getText().toString();
+ if (!TextUtils.isEmpty(Password) && !TextUtils.isEmpty(Hint)) {// 输入不为空
+ // Toast.makeText(getApplicationContext(), Password, Toast.LENGTH_SHORT).show();
+ // 加到数据库里
+ mWorkingNote.setmPwd(Password, Hint);
+ saveNote();
+ mWorkingNote.setCheckListMode(mWorkingNote.getCheckListMode() == 0 ? // 改workingnote的mMode的值,对应上文的菜单显示
+ TextNote.MODE_PRIVATE_TYPE : 0, false);
+ }
+ dialog.dismiss();// 撤销对话框
+ }
+
+ });
+ if (TextUtils.isEmpty(etPwd.getText())) {// 如果文件夹名称为空,则不能选择确定按钮
+ positive.setEnabled(false);
+ }
+ etPwd.addTextChangedListener(new TextWatcher() {// 添加文本更改监听器,即判断文本更改状态
+ public void beforeTextChanged(CharSequence s, int start, int count, int after) {// 文本更改之前(未完成)
+ // TODO Auto-generated method stub
+ }
+
+ public void onTextChanged(CharSequence s, int start, int before, int count) {// 当前文本改变触发,
+ if (TextUtils.isEmpty(etPwd.getText())) {// 文本为空确定按键不可用,不为空则可用
+ positive.setEnabled(false);
+ } else {
+ positive.setEnabled(true);
+ }
+ }
+
+ public void afterTextChanged(Editable s) {// 文本修改之后(未完成)
+ // TODO Auto-generated method stub
+ }
+ });
+ }
+
+ private void delPwd() {
+ mWorkingNote.delmPwd();
+ saveNote();
+ mWorkingNote.setCheckListMode(mWorkingNote.getCheckListMode() == 0 ? TextNote.MODE_PRIVATE_TYPE : 0, false);
+ }
+
+ private void callGallery() {
+ ActivityCompat.requestPermissions(NoteEditActivity.this,
+ new String[] { Manifest.permission.WRITE_EXTERNAL_STORAGE }, 1);// 动态申请权限
+ ActivityCompat.requestPermissions(NoteEditActivity.this,
+ new String[] { Manifest.permission.READ_EXTERNAL_STORAGE }, 1);// 动态申请权限
+ Intent getAlbum = new Intent(Intent.ACTION_PICK);// 隐私传递intent
+ getAlbum.setType("image/*");
+ startActivityForResult(getAlbum, 1);// 以请求码为1(onActivityResult方法里会处理),开始活动。
+ }
+
+ @Override
+ protected void onActivityResult(int requestCode, int resultCode, Intent data) {// 处理从图库中返回的图片。
+ switch (requestCode) {
+ case 1:
+ // 对于上面的callGallery()方法
+ try {
+ // 获得图片的uri
+ Uri originalUri = data.getData();
+ String[] proj = { MediaStore.Images.Media.DATA };
+ // 创建从数据库中查询的光标
+ Cursor cursor = getContentResolver().query(originalUri, proj, null, null, null);
+ // 获得用户选择的图片的索引值
+ int column_index = cursor.getColumnIndexOrThrow(MediaStore.Images.Media.DATA);
+ // 将光标移至开头
+ cursor.moveToFirst();
+ // 最后根据索引值获取图片路径
+ String path = cursor.getString(column_index);
+ // 插入图片
+ insertImg(path);
+ } catch (Exception e) {
+ e.printStackTrace();
+ Toast.makeText(NoteEditActivity.this, "图片插入失败", Toast.LENGTH_SHORT).show();
+ }
+ break;
+ case 3:// 开始画画
+ try {
+ if (resultCode == RESULT_OK) {
+ String tagPath = "";
+ SpannableString ss = new SpannableString(tagPath);
+ // 将画显示出来
+ insertPhotoToEditText(ss);
+ initImage();
+ }
+ } catch (Exception e) {
+ e.printStackTrace();
+ Toast.makeText(NoteEditActivity.this, "画图失败", Toast.LENGTH_SHORT).show();
+ }
+ break;
+ default:
+ break;
+ }
+ }
+
+ private void insertImg(String path) {
+ String tagPath = "";// 为图片路径加上标签
+ Bitmap bitmap = BitmapFactory.decodeFile(path);// 根据路径找到图片
+ if (bitmap != null) {
+ // 格式化存储路径
+ SpannableString ss = getBitmapMime(path, tagPath);
+ // 将图片插入文本视图
+ insertPhotoToEditText(ss);
+ Log.d("insertimage", path + "与" + tagPath);
+ } else {
+ Toast.makeText(NoteEditActivity.this, "插入失败,无读写存储权限,请到权限中心开启", Toast.LENGTH_LONG).show();
+ }
+ }
+
+ private SpannableString getBitmapMime(String path, String tagPath) {
+ SpannableString ss = new SpannableString(tagPath);// 这里使用加了标签的图片路径
+ int width = ScreenUtils.getScreenWidth(NoteEditActivity.this);
+ BitmapFactory.Options options = new BitmapFactory.Options();
+ // 路径对应的图片
+ Bitmap bitmap = BitmapFactory.decodeFile(path, options);
+ // 适应屏幕,锁定横纵比缩小图片。
+ bitmap = ImageUtils.zoomImage(bitmap, (width - 32) * 0.8,
+ bitmap.getHeight() / (bitmap.getWidth() / ((width - 32) * 0.8)));
+ ImageSpan imageSpan = new ImageSpan(this, bitmap);
+ ss.setSpan(imageSpan, 0, tagPath.length(), Spanned.SPAN_EXCLUSIVE_EXCLUSIVE);
+ return ss;
+ }
+
+ private void insertPhotoToEditText(SpannableString ss) {// 把文本插入便签,如
+ Editable et = mNoteEditor.getText();
+ int start = mNoteEditor.getSelectionStart();
+ ss.getSpans(0, ss.length(), ImageSpan.class);
+ // 将图片添加进EditText中
+ if (start < 0 || start >= et.length()) {
+ // 如果是在文本的结尾
+ et.append(ss);
+ } else {
+ // 如果是在文本的中间
+ et.insert(start, ss);
+ }
+ // 图片路径写入数据库
+ mWorkingNote.setWorkingText(et + "\n");
+ mNoteEditor.setText(et);
+ mNoteEditor.setSelection(start + ss.length());
+ mNoteEditor.setFocusableInTouchMode(true);
+ mNoteEditor.setFocusable(true);
+ }
+
+ private void initImage() {
+ String input = String.valueOf(mWorkingNote.getContent());
+ if (!input.equals("null")) {// 创建新便签时,input的值是“null”
+ Pattern p = Pattern.compile("\\");
+ Matcher m = p.matcher(input);
+ SpannableString spannable = new SpannableString(input);
+ while (m.find()) {
+ String s = m.group();
+ int start = m.start();
+ int end = m.end();
+ String path = s.replaceAll("\\", "").trim();// 得到路径
+
+ int width = ScreenUtils.getScreenWidth(NoteEditActivity.this);// 屏幕的宽度
+ try {
+ BitmapFactory.Options options = new BitmapFactory.Options();
+ Bitmap bitmap = BitmapFactory.decodeFile(path, options);
+ // 适应屏幕,锁定横纵比缩小图片。
+ bitmap = ImageUtils.zoomImage(bitmap, (width - 32) * 0.8,
+ bitmap.getHeight() / (bitmap.getWidth() / ((width - 32) * 0.8)));
+ ImageSpan imageSpan = new ImageSpan(NoteEditActivity.this, bitmap); // 用ImageSpan显示图片
+ spannable.setSpan(imageSpan, start, end, Spannable.SPAN_INCLUSIVE_EXCLUSIVE);
+ } catch (Exception e) {
+ e.printStackTrace();
+ }
+ }
+
+ mNoteEditor.setVisibility(View.VISIBLE);
+ mNoteEditor.setText(spannable);
+ }
+ }
+
+ private void saveCameraImage(Intent data) {// 存储图片至SD卡
+ // 检查sd card是否存在
+ if (!Environment.getExternalStorageState().equals(Environment.MEDIA_MOUNTED)) {
+ Log.i(TAG, "sd card is not avaiable/writeable right now.");
+ return;
+ }
+ // 为图片命名啊
+ Bitmap bmp = (Bitmap) data.getExtras().get("data");// 解析返回的图片成bitmap
+ // 保存文件
+ FileOutputStream fos = null;
+ // 根据SD卡的路径创建文件对象
+ File file = new File(getExternalCacheDir(), pathTakingPhoto);
+ try {
+ fos = new FileOutputStream(file.toString());
+ // 将图片储存到SD卡处
+ bmp.compress(Bitmap.CompressFormat.JPEG, 100, fos);
+ } catch (FileNotFoundException | NullPointerException e) {
+ e.printStackTrace();
+ } finally {
+ try {
+ fos.flush();
+ fos.close();
+ } catch (NullPointerException | IOException e) {
+ // TODO Auto-generated catch block
+ e.printStackTrace();
+ }
+ }
+ }
+
+ private void startDraw() {
+ ActivityCompat.requestPermissions(NoteEditActivity.this,
+ new String[] { Manifest.permission.WRITE_EXTERNAL_STORAGE }, 1);// 动态申请权限
+ ActivityCompat.requestPermissions(NoteEditActivity.this,
+ new String[] { Manifest.permission.READ_EXTERNAL_STORAGE }, 1);// 动态申请权限
+ // 启动相机程序
+ Intent getAlbum = new Intent(this, MyBoard.class);// 传递intent,画板
+ startActivityForResult(getAlbum, 3);// 以请求码为3,开始活动
+ }
+}
diff --git a/src/src/app/src/main/java/net/micode/notes/ui/NoteEditText.java b/src/src/app/src/main/java/net/micode/notes/ui/NoteEditText.java
new file mode 100644
index 0000000..9ac579b
--- /dev/null
+++ b/src/src/app/src/main/java/net/micode/notes/ui/NoteEditText.java
@@ -0,0 +1,219 @@
+/*
+ * Copyright (c) 2010-2011, The MiCode Open Source Community (www.micode.net)
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+
+package net.micode.notes.ui;
+
+import android.content.Context;
+import android.graphics.Rect;
+import android.text.Layout;
+import android.text.Selection;
+import android.text.Spanned;
+import android.text.TextUtils;
+import android.text.style.URLSpan;
+import android.util.AttributeSet;
+import android.util.Log;
+import android.view.ContextMenu;
+import android.view.KeyEvent;
+import android.view.MenuItem;
+import android.view.MenuItem.OnMenuItemClickListener;
+import android.view.MotionEvent;
+import android.widget.EditText;
+
+import net.micode.notes.R;
+
+import java.util.HashMap;
+import java.util.Map;
+
+public class NoteEditText extends androidx.appcompat.widget.AppCompatEditText {
+ private static final String TAG = "NoteEditText";
+ private int mIndex;
+ private int mSelectionStartBeforeDelete;
+
+ private static final String SCHEME_TEL = "tel:" ;
+ private static final String SCHEME_HTTP = "http:" ;
+ private static final String SCHEME_EMAIL = "mailto:" ;
+
+ private static final Map sSchemaActionResMap = new HashMap();
+ static {
+ sSchemaActionResMap.put(SCHEME_TEL, R.string.note_link_tel);
+ sSchemaActionResMap.put(SCHEME_HTTP, R.string.note_link_web);
+ sSchemaActionResMap.put(SCHEME_EMAIL, R.string.note_link_email);
+ }
+
+ /**
+ * Call by the {@link NoteEditActivity} to delete or add edit text
+ */
+ public interface OnTextViewChangeListener {
+ /**
+ * Delete current edit text when {@link KeyEvent#KEYCODE_DEL} happens
+ * and the text is null
+ */
+ void onEditTextDelete(int index, String text);
+
+ /**
+ * Add edit text after current edit text when {@link KeyEvent#KEYCODE_ENTER}
+ * happen
+ */
+ void onEditTextEnter(int index, String text);
+
+ /**
+ * Hide or show item option when text change
+ */
+ void onTextChange(int index, boolean hasText);
+ }
+
+ private OnTextViewChangeListener mOnTextViewChangeListener;
+
+ public NoteEditText(Context context) {
+ super(context, null);
+ mIndex = 0;
+ }
+
+ public void setIndex(int index) {
+ mIndex = index;
+ }
+
+ public void setOnTextViewChangeListener(OnTextViewChangeListener listener) {
+ mOnTextViewChangeListener = listener;
+ }
+
+ public NoteEditText(Context context, AttributeSet attrs) {
+ super(context, attrs, android.R.attr.editTextStyle);
+ }
+
+ public NoteEditText(Context context, AttributeSet attrs, int defStyle) {
+ super(context, attrs, defStyle);
+ // TODO Auto-generated constructor stub
+ }
+
+ @Override
+ public boolean onTouchEvent(MotionEvent event) {
+ switch (event.getAction()) {
+ case MotionEvent.ACTION_DOWN:
+
+ int x = (int) event.getX();
+ int y = (int) event.getY();
+ x -= getTotalPaddingLeft();
+ y -= getTotalPaddingTop();
+ x += getScrollX();
+ y += getScrollY();
+
+ Layout layout = getLayout();
+ int line = layout.getLineForVertical(y);
+ int off = layout.getOffsetForHorizontal(line, x);
+ Selection.setSelection(getText(), off);
+ break;
+ default:
+ break;
+ }
+
+ return super.onTouchEvent(event);
+ }
+
+ @Override
+ public boolean onKeyDown(int keyCode, KeyEvent event) {
+ switch (keyCode) {
+ case KeyEvent.KEYCODE_ENTER://回车键
+ if (mOnTextViewChangeListener != null) {
+ return false;
+ }
+ break;
+ case KeyEvent.KEYCODE_DEL://Backspace键
+ mSelectionStartBeforeDelete = getSelectionStart();
+ break;
+ default:
+ break;
+ }
+ return super.onKeyDown(keyCode, event);//其他按键,如数字键和字母键等
+ }
+
+ @Override
+ public boolean onKeyUp(int keyCode, KeyEvent event) {
+ switch(keyCode) {
+ case KeyEvent.KEYCODE_DEL:
+ if (mOnTextViewChangeListener != null) {
+ if (0 == mSelectionStartBeforeDelete && mIndex != 0) {
+ mOnTextViewChangeListener.onEditTextDelete(mIndex, getText().toString());
+ return true;
+ }
+ } else {
+ Log.d(TAG, "OnTextViewChangeListener was not seted");
+ }
+ break;
+ case KeyEvent.KEYCODE_ENTER:
+ if (mOnTextViewChangeListener != null) {
+ int selectionStart = getSelectionStart();
+ String text = getText().subSequence(selectionStart, length()).toString();
+ setText(getText().subSequence(0, selectionStart));
+ mOnTextViewChangeListener.onEditTextEnter(mIndex + 1, text);
+ } else {
+ Log.d(TAG, "OnTextViewChangeListener was not seted");
+ }
+ break;
+ default:
+ break;
+ }
+ return super.onKeyUp(keyCode, event);
+ }
+
+ @Override
+ protected void onFocusChanged(boolean focused, int direction, Rect previouslyFocusedRect) {//选择的便签改变,改变文档的内容
+ if (mOnTextViewChangeListener != null) {
+ if (!focused && TextUtils.isEmpty(getText())) {
+ mOnTextViewChangeListener.onTextChange(mIndex, false);
+ } else {
+ mOnTextViewChangeListener.onTextChange(mIndex, true);
+ }
+ }
+ super.onFocusChanged(focused, direction, previouslyFocusedRect);
+ }
+
+ @Override
+ protected void onCreateContextMenu(ContextMenu menu) {//长按便签后,一些对应便签内容的菜单
+ if (getText() instanceof Spanned) {
+ int selStart = getSelectionStart();
+ int selEnd = getSelectionEnd();
+
+ int min = Math.min(selStart, selEnd);
+ int max = Math.max(selStart, selEnd);
+
+ final URLSpan[] urls = ((Spanned) getText()).getSpans(min, max, URLSpan.class);//获得连接和电话号码
+ if (urls.length == 1) {
+ int defaultResId = 0;
+ for(String schema: sSchemaActionResMap.keySet()) {//可以
+ if(urls[0].getURL().indexOf(schema) >= 0) {
+ defaultResId = sSchemaActionResMap.get(schema);
+ break;
+ }
+ }
+
+ if (defaultResId == 0) {
+ defaultResId = R.string.note_link_other;//打开地图
+ }
+
+ menu.add(0, 0, 0, defaultResId).setOnMenuItemClickListener(
+ new OnMenuItemClickListener() {
+ public boolean onMenuItemClick(MenuItem item) {
+ // goto a new intent
+ urls[0].onClick(NoteEditText.this);
+ return true;
+ }
+ });
+ }
+ }
+ super.onCreateContextMenu(menu);
+ }
+}
diff --git a/src/src/app/src/main/java/net/micode/notes/ui/NoteItemData.java b/src/src/app/src/main/java/net/micode/notes/ui/NoteItemData.java
new file mode 100644
index 0000000..6567386
--- /dev/null
+++ b/src/src/app/src/main/java/net/micode/notes/ui/NoteItemData.java
@@ -0,0 +1,241 @@
+/*
+ * Copyright (c) 2010-2011, The MiCode Open Source Community (www.micode.net)
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+
+package net.micode.notes.ui;
+
+import android.content.Context;
+import android.database.Cursor;
+import android.text.TextUtils;
+
+import net.micode.notes.data.Contact;
+import net.micode.notes.data.Notes;
+import net.micode.notes.data.Notes.NoteColumns;
+import net.micode.notes.model.Note;
+import net.micode.notes.tool.DataUtils;
+
+//mine 5
+public class NoteItemData {
+ static final String [] PROJECTION = new String [] {
+ NoteColumns.ID,
+ NoteColumns.ALERTED_DATE,
+ NoteColumns.BG_COLOR_ID,
+ NoteColumns.CREATED_DATE,
+ NoteColumns.HAS_ATTACHMENT,
+ NoteColumns.MODIFIED_DATE,
+ NoteColumns.NOTES_COUNT,
+ NoteColumns.PARENT_ID,
+ NoteColumns.SNIPPET,
+ NoteColumns.TYPE,
+ NoteColumns.WIDGET_ID,
+ NoteColumns.WIDGET_TYPE,
+ NoteColumns.PASSWORD,//mine
+ NoteColumns.HINT
+ };
+
+ private static final int ID_COLUMN = 0;
+ private static final int ALERTED_DATE_COLUMN = 1;
+ private static final int BG_COLOR_ID_COLUMN = 2;
+ private static final int CREATED_DATE_COLUMN = 3;
+ private static final int HAS_ATTACHMENT_COLUMN = 4;
+ private static final int MODIFIED_DATE_COLUMN = 5;
+ private static final int NOTES_COUNT_COLUMN = 6;
+ private static final int PARENT_ID_COLUMN = 7;
+ private static final int SNIPPET_COLUMN = 8;
+ private static final int TYPE_COLUMN = 9;
+ private static final int WIDGET_ID_COLUMN = 10;
+ private static final int WIDGET_TYPE_COLUMN = 11;
+ private static final int PASSWORD = 12;
+ private static final int HINT = 13;
+
+ private long mId;
+ private long mAlertDate;//提醒时间
+ private int mBgColorId;//背景颜色id
+ private long mCreatedDate;
+ private boolean mHasAttachment;
+ private long mModifiedDate;
+ private int mNotesCount;
+ private long mParentId;
+ private String mSnippet;
+ private int mType;
+ private int mWidgetId;
+ private int mWidgetType;
+ private String mName;
+ private String mPhoneNumber;
+ private String mPassWord;
+ private String mHint;
+
+ private boolean mIsLastItem;
+ private boolean mIsFirstItem;
+ private boolean mIsOnlyOneItem;
+ private boolean mIsOneNoteFollowingFolder;
+ private boolean mIsMultiNotesFollowingFolder;
+
+ public NoteItemData(Context context, Cursor cursor) {
+ mId = cursor.getLong(ID_COLUMN);
+ mAlertDate = cursor.getLong(ALERTED_DATE_COLUMN);
+ mBgColorId = cursor.getInt(BG_COLOR_ID_COLUMN);
+ mCreatedDate = cursor.getLong(CREATED_DATE_COLUMN);
+ mHasAttachment = (cursor.getInt(HAS_ATTACHMENT_COLUMN) > 0) ? true : false;
+ mModifiedDate = cursor.getLong(MODIFIED_DATE_COLUMN);
+ mNotesCount = cursor.getInt(NOTES_COUNT_COLUMN);
+ mParentId = cursor.getLong(PARENT_ID_COLUMN);
+ mSnippet = cursor.getString(SNIPPET_COLUMN);
+ mSnippet = mSnippet.replace(NoteEditActivity.TAG_CHECKED, "").replace(
+ NoteEditActivity.TAG_UNCHECKED, "");
+ mType = cursor.getInt(TYPE_COLUMN);
+ mWidgetId = cursor.getInt(WIDGET_ID_COLUMN);
+ mWidgetType = cursor.getInt(WIDGET_TYPE_COLUMN);
+ mPassWord = cursor.getString(PASSWORD);//mine 2
+ mHint = cursor.getString(HINT);
+
+ mPhoneNumber = "";
+ if (mParentId == Notes.ID_CALL_RECORD_FOLDER) {
+ mPhoneNumber = DataUtils.getCallNumberByNoteId(context.getContentResolver(), mId);
+ if (!TextUtils.isEmpty(mPhoneNumber)) {
+ mName = Contact.getContact(context, mPhoneNumber);
+ if (mName == null) {
+ mName = mPhoneNumber;
+ }
+ }
+ }
+
+ if (mName == null) {
+ mName = "";
+ }
+
+ checkPostion(cursor);
+ }
+
+ private void checkPostion(Cursor cursor) {
+ mIsLastItem = cursor.isLast() ? true : false;
+ mIsFirstItem = cursor.isFirst() ? true : false;
+ mIsOnlyOneItem = (cursor.getCount() == 1);
+ mIsMultiNotesFollowingFolder = false;
+ mIsOneNoteFollowingFolder = false;
+
+ if (mType == Notes.TYPE_NOTE && !mIsFirstItem) {
+ int position = cursor.getPosition();
+ if (cursor.moveToPrevious()) {
+ if (cursor.getInt(TYPE_COLUMN) == Notes.TYPE_FOLDER
+ || cursor.getInt(TYPE_COLUMN) == Notes.TYPE_SYSTEM) {
+ if (cursor.getCount() > (position + 1)) {
+ mIsMultiNotesFollowingFolder = true;
+ } else {
+ mIsOneNoteFollowingFolder = true;
+ }
+ }
+ if (!cursor.moveToNext()) {
+ throw new IllegalStateException("cursor move to previous but can't move back");
+ }
+ }
+ }
+ }
+ //mine 2
+ public String getmHint(){
+ return mHint;
+ }
+ public String getmPassWord(){
+ return mPassWord;
+}
+
+ public boolean isOneFollowingFolder() {
+ return mIsOneNoteFollowingFolder;
+ }
+
+ public boolean isMultiFollowingFolder() {
+ return mIsMultiNotesFollowingFolder;
+ }
+
+ public boolean isLast() {
+ return mIsLastItem;
+ }
+
+ public String getCallName() {
+ return mName;
+ }
+
+ public boolean isFirst() {
+ return mIsFirstItem;
+ }
+
+ public boolean isSingle() {
+ return mIsOnlyOneItem;
+ }
+
+ public long getId() {
+ return mId;
+ }
+
+ public long getAlertDate() {
+ return mAlertDate;
+ }
+
+ public long getCreatedDate() {
+ return mCreatedDate;
+ }
+
+ public boolean hasAttachment() {
+ return mHasAttachment;
+ }
+
+ public long getModifiedDate() {
+ return mModifiedDate;
+ }
+
+ public int getBgColorId() {
+ return mBgColorId;
+ }
+
+ public long getParentId() {
+ return mParentId;
+ }
+
+ public int getNotesCount() {
+ return mNotesCount;
+ }
+
+ public long getFolderId () {
+ return mParentId;
+ }
+
+ public int getType() {
+ return mType;
+ }
+
+ public int getWidgetType() {
+ return mWidgetType;
+ }
+
+ public int getWidgetId() {
+ return mWidgetId;
+ }
+
+ public String getSnippet() {
+ return mSnippet;
+ }
+
+ public boolean hasAlert() {
+ return (mAlertDate > 0);
+ }
+
+ public boolean isCallRecord() {
+ return (mParentId == Notes.ID_CALL_RECORD_FOLDER && !TextUtils.isEmpty(mPhoneNumber));
+ }
+
+ public static int getNoteType(Cursor cursor) {
+ return cursor.getInt(TYPE_COLUMN);
+ }
+}
diff --git a/src/src/app/src/main/java/net/micode/notes/ui/NotesListActivity.java b/src/src/app/src/main/java/net/micode/notes/ui/NotesListActivity.java
new file mode 100644
index 0000000..5c6db96
--- /dev/null
+++ b/src/src/app/src/main/java/net/micode/notes/ui/NotesListActivity.java
@@ -0,0 +1,1227 @@
+/*
+ * Copyright (c) 2010-2011, The MiCode Open Source Community (www.micode.net)
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+
+package net.micode.notes.ui;
+
+import android.Manifest;
+import android.annotation.SuppressLint;
+import android.annotation.TargetApi;
+import android.app.Activity;
+import android.app.AlertDialog;
+import android.app.Dialog;
+import android.appwidget.AppWidgetManager;
+import android.content.AsyncQueryHandler;
+import android.content.ContentResolver;
+import android.content.ContentValues;
+import android.content.Context;
+import android.content.DialogInterface;
+import android.content.Intent;
+import android.content.SharedPreferences;
+import android.database.Cursor;
+import android.database.sqlite.SQLiteDatabase;
+import android.gesture.Gesture;
+import android.gesture.GestureLibraries;
+import android.gesture.GestureLibrary;
+import android.gesture.GestureOverlayView;
+import android.gesture.Prediction;
+import android.os.AsyncTask;
+import android.os.Build;
+import android.os.Bundle;
+import android.preference.PreferenceManager;
+import android.text.Editable;
+import android.text.TextUtils;
+import android.text.TextWatcher;
+import android.util.Log;
+import android.view.ActionMode;
+import android.view.ContextMenu;
+import android.view.ContextMenu.ContextMenuInfo;
+import android.view.Display;
+import android.view.GestureDetector;
+import android.view.HapticFeedbackConstants;
+import android.view.LayoutInflater;
+import android.view.Menu;
+import android.view.MenuItem;
+import android.view.MenuItem.OnMenuItemClickListener;
+import android.view.MotionEvent;
+import android.view.View;
+import android.view.View.OnClickListener;
+import android.view.View.OnCreateContextMenuListener;
+import android.view.View.OnTouchListener;
+import android.view.inputmethod.InputMethodManager;
+import android.widget.AdapterView;
+import android.widget.AdapterView.OnItemClickListener;
+import android.widget.AdapterView.OnItemLongClickListener;
+import android.widget.Button;
+import android.widget.EditText;
+import android.widget.ListView;
+import android.widget.PopupMenu;
+import android.widget.TextView;
+import android.widget.Toast;
+
+import androidx.core.app.ActivityCompat;
+
+import net.micode.notes.R;
+import net.micode.notes.data.Notes;
+import net.micode.notes.data.Notes.NoteColumns;
+import net.micode.notes.data.NotesDatabaseHelper;
+import net.micode.notes.gtask.remote.GTaskSyncService;
+import net.micode.notes.model.WorkingNote;
+import net.micode.notes.tool.BackupUtils;
+import net.micode.notes.tool.DataUtils;
+import net.micode.notes.tool.ResourceParser;
+import net.micode.notes.tool.ScreenUtils;
+import net.micode.notes.ui.NotesListAdapter.AppWidgetAttribute;
+import net.micode.notes.widget.NoteWidgetProvider_2x;
+import net.micode.notes.widget.NoteWidgetProvider_4x;
+
+import java.io.BufferedReader;
+import java.io.IOException;
+import java.io.InputStream;
+import java.io.InputStreamReader;
+import java.util.ArrayList;
+import java.util.HashSet;
+
+public class NotesListActivity extends Activity implements OnClickListener, OnItemLongClickListener {//点击监听器和长按监听器两个接口
+ //final 表示不想被继承
+ private static final int FOLDER_NOTE_LIST_QUERY_TOKEN = 0;
+ //查询记号:当从数据库中查询调取相关数据时,这个TOKEN会起到一个标签或指示器的作用
+ private static final int FOLDER_LIST_QUERY_TOKEN = 1;
+ //文件夹请求(长按便签然后点移动到文件夹)
+ private static final int MENU_FOLDER_DELETE = 0;
+
+ private static final int MENU_FOLDER_VIEW = 1;
+
+ private static final int MENU_FOLDER_CHANGE_NAME = 2;
+ //上面三个是对文件夹长按操作要用到的数值
+ private static final String PREFERENCE_ADD_INTRODUCTION = "net.micode.notes.introduction";
+
+ //用于第一次打开小米便签的判断
+ private enum ListEditState {
+ NOTE_LIST, SUB_FOLDER, CALL_RECORD_FOLDER
+ }
+ private NotesDatabaseHelper dbHelper = new NotesDatabaseHelper(this);
+
+ //enum是枚举
+ //编辑的三种状态,主界面,文件夹下和CALL_RECORD_FOLDER
+ //CALL_RECORD_FOLDER不清楚是什么界面
+ private ListEditState mState;
+ //列表编辑状态
+ private BackgroundQueryHandler mBackgroundQueryHandler;
+ //后台疑问处理
+ private NotesListAdapter mNotesListAdapter;
+ //笔记列表配适器
+ private ListView mNotesListView;
+ //主界面的视图
+ private Button mAddNewNote;
+ //最下方添加便签的按钮
+ private boolean mDispatch;
+ //是否调度
+ private int mOriginY;
+
+ private int mDispatchY;
+
+ private TextView mTitleBar;
+ //子文件夹下的 标头
+ private long mCurrentFolderId;
+ //当前文件夹的ID
+ private ContentResolver mContentResolver;
+ //提供内容分析
+ private ModeCallback mModeCallBack;
+ //返回调用方法
+ private static final String TAG = "NotesListActivity";
+ //名称
+ public static final int NOTES_LISTVIEW_SCROLL_RATE = 30;
+ //列表滚动速度
+ private NoteItemData mFocusNoteDataItem;
+ //光标聚焦的物件的数据
+ private static final String NORMAL_SELECTION = NoteColumns.PARENT_ID + "=?";
+
+ private static final String ROOT_FOLDER_SELECTION = "(" + NoteColumns.TYPE + "<>"
+ + Notes.TYPE_SYSTEM + " AND " + NoteColumns.PARENT_ID + "=?)" + " OR ("
+ + NoteColumns.ID + "=" + Notes.ID_CALL_RECORD_FOLDER + " AND "
+ + NoteColumns.NOTES_COUNT + ">0)";
+
+ private final static int REQUEST_CODE_OPEN_NODE = 102;//打开某个便签时返回的
+ private final static int REQUEST_CODE_NEW_NODE = 103;//新建便签时返回的
+ //mine 8
+ private final static int GESTURE_SETTING = 104;
+ private AlertDialog alertDialog1;
+ private GestureDetector mGestureDetector;
+ private GestureLibrary library;
+ private GestureOverlayView gestures_overlay;
+ private TextView gestureViewName;
+ private int GestureMode = 0;
+ @Override
+ protected void onCreate(Bundle savedInstanceState) {//创建活动,为防止切换到别的活动时,因为内存不足此活动被回收,所以用存储的状态做参数
+ super.onCreate(savedInstanceState);//调用父类的创建,以保存的状态为参数
+ setContentView(R.layout.note_list);//设置视图
+ initResources();//初始化内容
+
+ /**
+ * Insert an introduction when user firstly use this application
+ */
+ setAppInfoFromRawRes();//从Res文件下的资源,加载便签
+ }
+ //mine 4
+ @Override
+ protected void onResume() {
+ super.onResume();
+ GestureLoad();
+ }
+ //mine 21
+ private void GestureLoad(){
+ }
+ @Override
+ protected void onStart() {//在onActivityResult之后调用,此活动变为可见时使用
+ super.onStart();//调用父类,启动活动
+ startAsyncNotesListQuery();//同步便签列表
+ }
+//mine 3
+ @Override
+ protected void onActivityResult(int requestCode, int resultCode, Intent data) {//从一个活动被销毁时,转换成另一个活动时会调用
+ if (resultCode == RESULT_OK
+ && (requestCode == REQUEST_CODE_OPEN_NODE || requestCode == REQUEST_CODE_NEW_NODE)) {
+ mNotesListAdapter.changeCursor(null);//从编辑界面返回应该把在便签内的光标删除
+ //RESULT_OK是另外一个活动返回的数据,保存便签时会出现,删除与桌面挂件有关联的便签或文件夹会出现
+ }else if(resultCode == RESULT_OK && requestCode == GESTURE_SETTING)
+ {
+ GestureMode = 1;
+ GestureLoad();
+ }else {
+ super.onActivityResult(requestCode, resultCode, data);//调用父类的方法
+ }
+ }
+
+ //try语句允许我们定义在执行时进行错误测试的代码块。
+//catch 语句允许我们定义当 try 代码块发生错误时,所执行的代码块。
+//finally 语句在 try 和 catch 之后无论有无异常都会执行。
+ @TargetApi(Build.VERSION_CODES.KITKAT)
+ private void setAppInfoFromRawRes() {
+ //作用:从res中的raw文件夹中导入资源,具体来说,载入一开始的便签的内容
+ SharedPreferences sp = PreferenceManager.getDefaultSharedPreferences(this);
+ if (!sp.getBoolean(PREFERENCE_ADD_INTRODUCTION, false)) {
+ //getBoolean :判断if 不存在第一个参数,返回false的值。这里如果是第一次进入小米便签,则执行下面的语句
+ StringBuilder sb = new StringBuilder();//代表一个字符序列可变的字符串,线程不安全,但性能较高
+ InputStream in = null;
+ try {
+ in = getResources().openRawResource(R.raw.introduction);//加载Welcome to use MIUI notes!
+ try (InputStreamReader isr = new InputStreamReader(in); BufferedReader br = new BufferedReader(isr);) {
+ //使用指定的字符集读取字节并将它们解码为字符
+ //缓冲区流读入
+ char[] buf = new char[1024];
+ int len = 0;
+ while ((len = br.read(buf)) > 0) {//read读取一个字符,若读取到末尾则返回-1,这里是加载到buf中
+ sb.append(buf, 0, len);//从buf0开始的len长度的字符串加载到sb后
+ }
+
+ }
+ } catch (IOException e) {//把捕获的异常交给e
+ //e.printStackTrace();//在命令行打印异常信息在程序中出错的位置及原因
+ Log.e(TAG, "setAppInfoFromRawRes: " + e.toString());
+ return;
+ } finally {
+ if (in != null) {
+ try {
+ in.close();
+ } catch (IOException e) {
+ Log.e(TAG, "setAppInfoFromRawRes: " + e.toString());
+ }
+ }
+ }
+
+ WorkingNote note = WorkingNote.createEmptyNote(this, Notes.ID_ROOT_FOLDER,
+ AppWidgetManager.INVALID_APPWIDGET_ID, Notes.TYPE_WIDGET_INVALIDE,
+ ResourceParser.RED);//在根目录下创建背景颜色是红的便签(初始设置未关联桌面挂件)
+ note.setWorkingText(sb.toString());//设置文本数据
+ if (note.saveNote()) {//如果保存成功就将PREFERENCE_ADD_INTRODUCTION的对应的值设置为true,对应开头的判断
+ sp.edit().putBoolean(PREFERENCE_ADD_INTRODUCTION, true).commit();
+ } else {
+ Log.e(TAG, "Save introduction note error");
+ return;
+ }
+ }
+ }
+
+ @SuppressLint({"ClickableViewAccessibility", "WrongViewCast"})
+ private void initResources() {
+ mContentResolver = this.getContentResolver();//获取应用数据
+ mBackgroundQueryHandler = new BackgroundQueryHandler(this.getContentResolver());//?
+ mCurrentFolderId = Notes.ID_ROOT_FOLDER;//当前文件夹ID是根目录ID
+ mNotesListView = (ListView) findViewById(R.id.notes_list);//findViewById是引用R文件里的引用名,这里是设置主活动的视图
+ mNotesListView.addFooterView(LayoutInflater.from(this).inflate(R.layout.note_list_footer, null),
+ null, false);//增加页脚 ?
+ mNotesListView.setOnItemClickListener(new OnListItemClickListener());//设置视图点击监听器
+ mNotesListView.setOnItemLongClickListener(this);//设置长按监听器
+ mNotesListView.setOnTouchListener(new OnTouchListener() {//mine
+ @Override
+ public boolean onTouch(View v, MotionEvent event) {
+ return mGestureDetector.onTouchEvent(event);//此处为传递
+ }
+ });//mine
+ mNotesListAdapter = new NotesListAdapter(this);//设置便签视图配置器
+ mNotesListView.setAdapter(mNotesListAdapter);
+ mAddNewNote = (Button) findViewById(R.id.btn_new_note);//获得最下方的创建便签的按键
+ mAddNewNote.setOnClickListener(this);//只对应下方的按键的点击监听器
+ mAddNewNote.setOnTouchListener(new NewNoteOnTouchListener());//获得更多的信息的监听器包括down-touch/up-touch/move等
+ mDispatch = false;//是否调度,主要用于新建便签模块
+ mDispatchY = 0;
+ mOriginY = 0;
+ mTitleBar = (TextView) findViewById(R.id.tv_title_bar);//文件夹下的标头
+ mState = ListEditState.NOTE_LIST;//设置状态为主界面
+ mModeCallBack = new ModeCallback();//对便签的方法调用,删除和移动
+ // mine4
+ mGestureDetector = new GestureDetector(new gesturelistener());
+ gestures_overlay = (GestureOverlayView) findViewById(R.id.gesture_view);
+ gestures_overlay.addOnGesturePerformedListener(new gestureOverlayListener());
+ gestureViewName = findViewById(R.id.gesture_view_name);
+ }
+
+ //设置监听 mine85
+ private class gestureOverlayListener implements GestureOverlayView.OnGesturePerformedListener {
+ @Override
+ public void onGesturePerformed(GestureOverlayView overlay,
+ Gesture gesture) {
+ //识别手势: 通过 library 读取手势文件 ,在这里读取
+ //这个列表包含定义好的手势,可以理解为键值对(名字:手势)
+ ArrayList predictions=library.recognize(gesture);
+ //这是绘制的手势,等下在手势数据库中比对
+ Prediction prediction=predictions.get(0);
+ //更加相似度 来 取得 区间(0.0~10.0 大致区间)
+ if(prediction.score>=3.0) {
+ //通过 name 来判断 值
+ if (prediction.name.equals("Create New Folder")) {
+ showCreateOrModifyFolderDialog(true);
+ }
+ }
+ else{
+ Toast.makeText(NotesListActivity.this,"手势无法匹配或者手势不存在",Toast.LENGTH_LONG);
+ }
+ gestures_overlay.setVisibility(View.GONE);//相应完将手势响应视图设置为不可见
+ gestureViewName.setVisibility(View.GONE);
+ }
+ }
+ private class gesturelistener implements GestureDetector.OnGestureListener{//mine
+
+ public boolean onDown(MotionEvent e) {
+ // TODO Auto-generated method stub
+ return false;
+ }
+ public void onShowPress(MotionEvent e) {
+ // TODO Auto-generated method stub
+ }
+ public boolean onSingleTapUp(MotionEvent e) {
+ // TODO Auto-generated method stub
+ return false;
+ }
+ public boolean onScroll(MotionEvent e1, MotionEvent e2,
+ float distanceX, float distanceY) {
+ // TODO Auto-generated method stub
+ return false;
+ }
+ public void onLongPress(MotionEvent e) {
+ // TODO Auto-generated method stub
+
+ }
+ public boolean onFling(MotionEvent e1, MotionEvent e2, float velocityX,
+ float velocityY) {
+ float minMoveY = (float)ScreenUtils.getScreenHeight(NotesListActivity.this)/4;// 最小滑动距离Y
+ float minVelocityY = (float)ScreenUtils.getScreenHeight(NotesListActivity.this)/3;// 最小滑动速度Y
+ float minMoveX = (float)ScreenUtils.getScreenWidth(NotesListActivity.this)/3; // 最小滑动距离X
+ float minVelocityX = (float)ScreenUtils.getScreenWidth(NotesListActivity.this)/2; // 最小滑动速度X
+ float beginX = e1.getX();
+ float endX = e2.getX();
+ float beginY = e1.getY();
+ float endY = e2.getY();
+ int normalGestureCase = 0;
+ if (Math.abs(beginX - endX) > minMoveX && Math.abs(beginY-endY) > minMoveY){//无效滑动
+ normalGestureCase = 0;
+ } else if (beginX - endX > minMoveX && Math.abs(velocityX) > minVelocityX) { // 左滑
+ normalGestureCase = 1;
+ }else if(endY - beginY > minMoveY && Math.abs(velocityY) > minVelocityY){//下滑
+ normalGestureCase = 2;
+ }
+ if(normalGestureCase == 1){
+ startPreferenceActivity();
+ }
+ else if(normalGestureCase == 2){
+ Toast.makeText(NotesListActivity.this,"进入手势界面",Toast.LENGTH_LONG);
+ gestures_overlay.setVisibility(View.VISIBLE);
+ gestureViewName.setVisibility(View.VISIBLE);
+ }
+ return true;
+ }
+ }
+ private class ModeCallback implements ListView.MultiChoiceModeListener, OnMenuItemClickListener {//对便签的方法调用,删除和移动,继承多选监听器(用于批量处理便签)和菜单点击监听器
+ private DropdownMenu mDropDownMenu;//下拉的菜单
+ private ActionMode mActionMode;//表面目前进行的是删除还是移动
+ private MenuItem mMoveMenu;//移动的选项的实例
+
+ public boolean onCreateActionMode(ActionMode mode, Menu menu) {
+ getMenuInflater().inflate(R.menu.note_list_options, menu);//配置menu
+ //R是个文件,所有东西都在里面注册了 只有两种行为模式删除和移动到文件夹
+ menu.findItem(R.id.delete).setOnMenuItemClickListener(this);//这里关联上了listerner,专门关联在菜单的按键
+ mMoveMenu = menu.findItem(R.id.move);
+ if (mFocusNoteDataItem.getParentId() == Notes.ID_CALL_RECORD_FOLDER
+ || DataUtils.getUserFolderCount(mContentResolver) == 0) {
+ mMoveMenu.setVisible(false);// call note? 或者没有文件夹
+ } else {
+ mMoveMenu.setVisible(true);//当长按某一标签时,会执行这个,让 移动 按键变得可见
+ mMoveMenu.setOnMenuItemClickListener(this);
+ }
+ mActionMode = mode;
+ mNotesListAdapter.setChoiceMode(true);//进入选择模式,设置为true才能勾选便签
+ mNotesListView.setLongClickable(false);//选择模式下,不能长按
+ mAddNewNote.setVisibility(View.GONE);//选择模式下,不能添加性便签
+
+ View customView = LayoutInflater.from(NotesListActivity.this).inflate(
+ R.layout.note_list_dropdown_menu, null);//
+ mode.setCustomView(customView);
+ mDropDownMenu = new DropdownMenu(NotesListActivity.this,
+ (Button) customView.findViewById(R.id.selection_menu),
+ R.menu.note_list_dropdown);//
+ mDropDownMenu.setOnDropdownMenuItemClickListener(new PopupMenu.OnMenuItemClickListener() {
+ public boolean onMenuItemClick(MenuItem item) {//点击全选
+ mNotesListAdapter.selectAll(!mNotesListAdapter.isAllSelected());//把便签全选
+ updateMenu();//更新菜单界面
+ return true;
+ }
+
+ });
+ return true;
+ }
+
+ private void updateMenu() {//更新菜单ActionMode
+ int selectedCount = mNotesListAdapter.getSelectedCount();
+ // Update dropdown menu
+ String format = getResources().getString(R.string.menu_select_title, selectedCount);
+ mDropDownMenu.setTitle(format);
+ MenuItem item = mDropDownMenu.findItem(R.id.action_select_all);
+ if (item != null) {
+ if (mNotesListAdapter.isAllSelected()) {
+ item.setChecked(true);
+ item.setTitle(R.string.menu_deselect_all);
+ } else {
+ item.setChecked(false);
+ item.setTitle(R.string.menu_select_all);
+ }
+ }
+ }
+
+ public boolean onPrepareActionMode(ActionMode mode, Menu menu) {
+ // TODO Auto-generated method stub
+ return false;
+ }
+
+ public boolean onActionItemClicked(ActionMode mode, MenuItem item) {
+ // TODO Auto-generated method stub
+ return false;
+ }
+
+ public void onDestroyActionMode(ActionMode mode) {
+ mNotesListAdapter.setChoiceMode(false);//必须设置为false,不然还是可以选择便签,就进入不了便签了
+ mNotesListView.setLongClickable(true);
+ mAddNewNote.setVisibility(View.VISIBLE);
+ }
+
+ public void finishActionMode() {
+ mActionMode.finish();
+ }
+
+ public void onItemCheckedStateChanged(ActionMode mode, int position, long id,
+ boolean checked) {
+ mNotesListAdapter.setCheckedItem(position, checked);
+ updateMenu();
+ }
+
+ public boolean onMenuItemClick(MenuItem item) {
+ if (mNotesListAdapter.getSelectedCount() == 0) {
+ Toast.makeText(NotesListActivity.this, getString(R.string.menu_select_none),
+ Toast.LENGTH_SHORT).show();
+ return true;
+ }
+
+ switch (item.getItemId()) {//mine2
+ case R.id.delete:
+ if(NotExistPassword()){
+ AlertDialog.Builder builder = new AlertDialog.Builder(NotesListActivity.this);
+ builder.setTitle(getString(R.string.alert_title_delete));
+ builder.setIcon(android.R.drawable.ic_dialog_alert);
+ builder.setMessage(getString(R.string.alert_message_delete_notes,
+ mNotesListAdapter.getSelectedCount()));
+ builder.setPositiveButton(android.R.string.ok,
+ new DialogInterface.OnClickListener() {
+ public void onClick(DialogInterface dialog,
+ int which) {
+ Log.e(TAG, "onClick: which:" + which );
+ batchDelete();
+ }
+ });
+ builder.setNegativeButton(android.R.string.cancel, null);
+ builder.show();
+ }
+ else{
+ Toast.makeText(getApplicationContext(),"不能删除含有密码的便签",Toast.LENGTH_SHORT).show();
+ }
+ break;
+ case R.id.move:
+ startQueryDestinationFolders();//查询目的文件夹
+ break;
+ default:
+ return false;
+ }
+ return true;
+ }
+ }
+ public boolean NotExistPassword(){//mine 20
+ SQLiteDatabase db = null;//数据库对象
+ for (long id:mNotesListAdapter.getSelectedItemIds()) {
+ try{
+ db = dbHelper.getWritableDatabase();
+ } catch (NullPointerException e)
+ {
+ e.printStackTrace();
+ }
+ //对数据库查询的光标
+ assert db != null;
+ @SuppressLint("Recycle") Cursor cursor = db.query("note", new String[]{NoteColumns.ID,NoteColumns.PASSWORD},
+ "_id = ?",new String[]{String.valueOf(id)},null,null,null);
+ //防止遗漏,先把光标移到最上面
+ cursor.moveToFirst();
+ //找对应的密码
+ String p = cursor.getString(cursor.getColumnIndex("note_password"));
+ if(!p.equals(""))
+ {
+ return false;
+ }
+ }
+ return true;
+ }
+ //Ontouch 可以获得更多的信息,比如多点,触摸的强度,按下,松开,拖动等。。。。
+ //但Onclick 只适用于组件的事件触发
+ private class NewNoteOnTouchListener implements OnTouchListener {
+ public boolean onTouch(View v, MotionEvent event) {//行为动作和视图
+ switch (event.getAction()) {
+ case MotionEvent.ACTION_DOWN: {
+ Display display = getWindowManager().getDefaultDisplay();
+ int screenHeight = display.getHeight();//2712总高度
+ int newNoteViewHeight = mAddNewNote.getHeight();//2456-2059下面那个“新建标签”按钮的高度
+ int start = screenHeight - newNoteViewHeight;//2315起始的y值
+ int eventY = start + (int) event.getY();//event.getY相当于点击到的地方的y值
+ /**
+ * Minus TitleBar's height
+ */
+ if (mState == ListEditState.SUB_FOLDER) {//减去子文件夹的title的高度
+ eventY -= mTitleBar.getHeight();
+ start -= mTitleBar.getHeight();
+ }
+ /**
+ * HACKME:When click the transparent part of "New Note" button, dispatch
+ * the event to the list view behind this button. The transparent part of
+ * "New Note" button could be expressed by formula y=-0.12x+94(Unit:pixel)
+ * and the line top of the button. The coordinate based on left of the "New
+ * Note" button. The 94 represents maximum height of the transparent part.
+ * Notice that, if the background of the button changes, the formula should
+ * also change. This is very bad, just for the UI designer's strong requirement.
+ */
+ if (event.getY() < (event.getX() * (-0.12) + 94)) {//是下面写便签的那条斜线,此处判断是否在创建便签的按钮上
+ View view = mNotesListView.getChildAt(mNotesListView.getChildCount() - 1//getcount在此布局下的子元素个数,减一是因为索引从0开始
+ - mNotesListView.getFooterViewsCount());//减去页脚下元素布局数量
+ //最后得到最后一个元素的view
+ //Log.d(TAG,Integer.toString(mNotesListView.getChildCount()));
+ //Log.d(TAG,Integer.toString(mNotesListView.getFooterViewsCount()));
+ //Log.d(TAG,Integer.toString(view.getTop()));
+ //Log.d(TAG,Integer.toString(view.getBottom()));
+ if (view != null && view.getBottom() > start
+ && (view.getTop() < (start + 94))) {//如果不在新建便签的按钮上
+ mOriginY = (int) event.getY();
+ mDispatchY = eventY;
+ event.setLocation(event.getX(), mDispatchY);//重新赋值
+ mDispatch = true;
+ return mNotesListView.dispatchTouchEvent(event);//重新调度,即重新执行
+ }
+ }
+ break;
+ }
+ case MotionEvent.ACTION_MOVE: {
+ if (mDispatch) {
+ mDispatchY += (int) event.getY() - mOriginY;
+ event.setLocation(event.getX(), mDispatchY);//重新赋值
+ return mNotesListView.dispatchTouchEvent(event);//重新调度,即重新执行
+ }
+ break;
+ }
+ default: {//其他情况
+ if (mDispatch) {
+ event.setLocation(event.getX(), mDispatchY);//重新赋值
+ mDispatch = false;
+ return mNotesListView.dispatchTouchEvent(event);//重新调度,即重新执行
+ }
+ break;
+ }
+ }
+ return false;
+ }
+
+ }
+
+ private void startAsyncNotesListQuery() {//同步便签列表
+ String selection = (mCurrentFolderId == Notes.ID_ROOT_FOLDER) ? ROOT_FOLDER_SELECTION
+ : NORMAL_SELECTION;//如果当前ID和父文件夹ID相同,则为父文件夹模式,否则是常规模式
+ mBackgroundQueryHandler.startQuery(FOLDER_NOTE_LIST_QUERY_TOKEN, null,
+ Notes.CONTENT_NOTE_URI, NoteItemData.PROJECTION, selection, new String[]{
+ String.valueOf(mCurrentFolderId)//后台异步对数据库进行操作,加快数据处理速度
+ }, NoteColumns.TYPE + " DESC," + NoteColumns.MODIFIED_DATE + " DESC");
+ }
+
+ //3.函数:AsyncQueryHandler异步查询操作帮助类,可以处理增删改ContentProvider提供的数据。
+ // 通过提供onxxxComplete的回调窗口,实现事件的完成处理,API中提供Insert,Delete,updata,Query四种方法,
+ // BackgroundQueryHandler继承这个类,可以实现对数据库的查询操作
+ private final class BackgroundQueryHandler extends AsyncQueryHandler {//背景处理
+
+ //可以使用Activity提供的getContentResolver()方法来获取ContentResolver对象
+ public BackgroundQueryHandler(ContentResolver contentResolver) {//使用ContentResolver调用ContentProvider提供的接口,
+ // 对ContentProvider中的数据进行添加、删除、修改和查询操作时
+ super(contentResolver);
+ }
+
+ //1.异步查询框架AsyncQueryHandler,当单查询完毕后,会调用onQueryComplete(token, cookie, cursor)通知查询完毕,并且传回cursor
+ @Override
+ protected void onQueryComplete(int token, Object cookie, Cursor cursor) {//token判断情况,cookie,cursor光标判断选择的那个
+ switch (token) {
+ case FOLDER_NOTE_LIST_QUERY_TOKEN://便签列表请求,打开便签时会调用
+ mNotesListAdapter.changeCursor(cursor);// 如果是便签查询被采用,更改光标位置
+ break;
+ case FOLDER_LIST_QUERY_TOKEN://移动到文件夹请求(长按便签然后点移动到文件夹)
+ if (cursor != null && cursor.getCount() > 0) {//下面有便签
+ showFolderListMenu(cursor);//打开文件夹列表弹窗
+ } else {
+ Log.e(TAG, "Query folder failed");
+ }
+ break;
+ default:
+ return;
+ }
+ }
+ }
+
+ private void showFolderListMenu(Cursor cursor) {//长按便签后,点移动到文件夹,就会弹出文件夹列表弹窗
+ AlertDialog.Builder builder = new AlertDialog.Builder(NotesListActivity.this);//创建对话框实例
+ builder.setTitle(R.string.menu_title_select_folder);//title是选择文件夹
+ final FoldersListAdapter adapter = new FoldersListAdapter(this, cursor);//文件夹列表配适器
+ builder.setAdapter(adapter, new DialogInterface.OnClickListener() {//绑定配适器,对话框接口是点击监听器
+
+ public void onClick(DialogInterface dialog, int which) {
+ DataUtils.batchMoveToFolder(mContentResolver,//移动到文件夹下
+ mNotesListAdapter.getSelectedItemIds(), adapter.getItemId(which));
+ Toast.makeText(//发送消息
+ NotesListActivity.this,
+ getString(R.string.format_move_notes_to_folder,
+ mNotesListAdapter.getSelectedCount(),
+ adapter.getFolderName(NotesListActivity.this, which)),
+ Toast.LENGTH_SHORT).show();
+ mModeCallBack.finishActionMode();//完成动作
+ }
+ });
+ builder.show();//显示对话框
+ }
+
+ private void createNewNote(int openMode) {//mine 1
+ Intent intent = new Intent(this, NoteEditActivity.class);
+ intent.setAction(Intent.ACTION_INSERT_OR_EDIT);
+ intent.putExtra("open_mode",openMode);//不同的打开方式,加载不同的便签模板
+ intent.putExtra(Notes.INTENT_EXTRA_FOLDER_ID, mCurrentFolderId);
+ this.startActivityForResult(intent, REQUEST_CODE_NEW_NODE);
+ }
+
+ private void batchDelete() {//删除时候,会判断是否为桌面挂件 批量删除
+ new AsyncTask>() {
+ protected HashSet doInBackground(Void... unused) {
+ HashSet widgets = mNotesListAdapter.getSelectedWidget();
+ if (!isSyncMode()) {//如果不为同步模式则删除笔记,若删除不成功打印错误信息
+ // if not synced, delete notes directly
+ if (DataUtils.batchDeleteNotes(mContentResolver, mNotesListAdapter
+ .getSelectedItemIds())) {
+ } else {
+ Log.e(TAG, "Delete notes error, should not happens");
+ }
+ } else {//下面的注释挺好
+ // in sync mode, we'll move the deleted note into the trash
+ // folder
+ if (!DataUtils.batchMoveToFolder(mContentResolver, mNotesListAdapter
+ .getSelectedItemIds(), Notes.ID_TRASH_FOLER)) {
+ Log.e(TAG, "Move notes to trash folder error, should not happens");
+ }
+ }
+ return widgets;//桌面widget修改
+ }
+
+ @Override
+ protected void onPostExecute(HashSet widgets) {//遍历桌面挂件如果与刚才删除的便签有联系
+ if (widgets != null) {
+ for (AppWidgetAttribute widget : widgets) {
+ if (widget.widgetId != AppWidgetManager.INVALID_APPWIDGET_ID//此处判断是否为一个widget
+ && widget.widgetType != Notes.TYPE_WIDGET_INVALIDE) {//widget是否有效
+ updateWidget(widget.widgetId, widget.widgetType);//更新桌面挂件
+ }
+ }
+ }
+ mModeCallBack.finishActionMode();
+ }
+ }.execute();
+ }
+
+ private void deleteFolder(long folderId) {//删除文件夹
+ if (folderId == Notes.ID_ROOT_FOLDER) {//如果是父文件夹,则报错
+ Log.e(TAG, "Wrong folder id, should not happen " + folderId);
+ return;
+ }
+//下面会判断删除的文件夹里是否包含与桌面挂件相关联的便签
+ HashSet ids = new HashSet();
+ ids.add(folderId);
+ HashSet widgets = DataUtils.getFolderNoteWidget(mContentResolver,
+ folderId);
+ if (!isSyncMode()) {
+ // if not synced, delete folder directly
+ DataUtils.batchDeleteNotes(mContentResolver, ids);
+ } else {
+ // in sync mode, we'll move the deleted folder into the trash folder
+ DataUtils.batchMoveToFolder(mContentResolver, ids, Notes.ID_TRASH_FOLER);
+ }
+ if (widgets != null) {
+ for (AppWidgetAttribute widget : widgets) {
+ if (widget.widgetId != AppWidgetManager.INVALID_APPWIDGET_ID
+ && widget.widgetType != Notes.TYPE_WIDGET_INVALIDE) {
+ updateWidget(widget.widgetId, widget.widgetType);
+ }
+ }
+ }
+ }
+
+
+
+ private void openNode(NoteItemData data) {//打开便签,参数为数据
+ Intent intent = new Intent(this, NoteEditActivity.class);
+ intent.setAction(Intent.ACTION_VIEW);
+ intent.putExtra(Intent.EXTRA_UID, data.getId());
+ this.startActivityForResult(intent, REQUEST_CODE_OPEN_NODE);
+ }
+
+ private void openFolder(NoteItemData data) {//.打开文件夹
+ mCurrentFolderId = data.getId();//获取当前文件夹的id
+ startAsyncNotesListQuery();//开始开始异步的便签列表反馈
+ if (data.getId() == Notes.ID_CALL_RECORD_FOLDER) {//如果是call_record_folder类型的文件夹
+ mState = ListEditState.CALL_RECORD_FOLDER;//切换状态
+ mAddNewNote.setVisibility(View.GONE);//将新加便签的按钮设置为不可见
+ } else {
+ mState = ListEditState.SUB_FOLDER;//不然设置为子文件夹
+ }
+ if (data.getId() == Notes.ID_CALL_RECORD_FOLDER) {
+ mTitleBar.setText(R.string.call_record_folder_name);//title设置为call notes
+ } else {
+ mTitleBar.setText(data.getSnippet());//否则文本的前部片段内容,即文件夹名称
+ Log.d(TAG, data.getSnippet());
+ }
+ mTitleBar.setVisibility(View.VISIBLE);//设置title可见
+ }
+
+
+
+ public void onClick(View v) {//文件夹界面的点击相应的函数
+ switch (v.getId()) {
+ case R.id.btn_new_note://创建新便签
+ //打开选择便签的对话框
+ showNoteType();
+ break;
+ default:
+ break;
+ }
+ }
+
+ private void showSoftInput() {//显示软键盘
+ InputMethodManager inputMethodManager = (InputMethodManager) getSystemService(Context.INPUT_METHOD_SERVICE);//获取方法的管理者对象
+ if (inputMethodManager != null) {
+ inputMethodManager.toggleSoftInput(InputMethodManager.SHOW_FORCED, 0);//使软键盘显示,第二个参数hideFlags等于0
+ }
+ }
+
+ private void hideSoftInput(View view) {//隐藏软键盘
+ InputMethodManager inputMethodManager = (InputMethodManager) getSystemService(Context.INPUT_METHOD_SERVICE);
+ inputMethodManager.hideSoftInputFromWindow(view.getWindowToken(), 0);//隐藏软键盘
+ }
+
+ private void showCreateOrModifyFolderDialog(final boolean create) {//显示创建或者修改文件夹的对话框,菜单里的创建文件夹或者改名
+ final AlertDialog.Builder builder = new AlertDialog.Builder(this);//初始化对话框
+ View view = LayoutInflater.from(this).inflate(R.layout.dialog_edit_text, null);//加载对话框的布局文件
+ final EditText etName = (EditText) view.findViewById(R.id.et_foler_name);//初始化对话框里的文本对象
+ showSoftInput();//显示软键盘
+ if (!create) {//给文件夹改名
+ if (mFocusNoteDataItem != null) {
+ etName.setText(mFocusNoteDataItem.getSnippet());//提取文件夹的title
+ Log.d(TAG, mFocusNoteDataItem.getSnippet());
+ builder.setTitle(getString(R.string.menu_folder_change_name));//设置文本框,内容是change_name
+ } else {
+ Log.e(TAG, "The long click data item is null");
+ return;
+ }
+ } else {//创建文件夹
+ etName.setText("");//title为空
+ builder.setTitle(this.getString(R.string.menu_create_folder));//设置文本框,内容是new Folder
+ }
+
+ builder.setPositiveButton(android.R.string.ok, null);//确定按钮
+ builder.setNegativeButton(android.R.string.cancel, new DialogInterface.OnClickListener() {
+ public void onClick(DialogInterface dialog, int which) {//取消按钮
+ hideSoftInput(etName);//隐藏软键盘
+ }
+ });
+
+ final Dialog dialog = builder.setView(view).show();//显示出来
+ final Button positive = (Button) dialog.findViewById(android.R.id.button1);//加载确定按钮布局文件
+ positive.setOnClickListener(new OnClickListener() {
+ public void onClick(View v) {//设置确定按钮的接收器
+ hideSoftInput(etName);//点击确定后收起软键盘
+ String name = etName.getText().toString();//
+ if (DataUtils.checkVisibleFolderName(mContentResolver, name)) {//得到输入文件夹的名字判断文件夹名称是否已经存在
+ Toast.makeText(NotesListActivity.this, getString(R.string.folder_exist, name),//提示重新命名
+ Toast.LENGTH_LONG).show();
+ etName.setSelection(0, etName.length());//设置名称
+ return;
+ }
+ if (!create) {//如果是改名
+ if (!TextUtils.isEmpty(name)) {//输入不为空
+ ContentValues values = new ContentValues();//与Hashtable类似,负责存储名值对,名为string类型,值为基本类型
+ values.put(NoteColumns.SNIPPET, name);//存储snippet和文件夹名称的键值对
+ values.put(NoteColumns.TYPE, Notes.TYPE_FOLDER);//存储类型为文件夹
+ values.put(NoteColumns.LOCAL_MODIFIED, 1);//local_modified对应1 添加值到value里
+ mContentResolver.update(Notes.CONTENT_NOTE_URI, values, NoteColumns.ID
+ + "=?", new String[]{
+ String.valueOf(mFocusNoteDataItem.getId())
+ });//将内容笔记URI及笔记专栏ID更新至内容解决器
+ }
+ } else if (!TextUtils.isEmpty(name)) {//如果是新建,输入不空
+ ContentValues values = new ContentValues();
+ values.put(NoteColumns.SNIPPET, name);
+ values.put(NoteColumns.TYPE, Notes.TYPE_FOLDER);
+ mContentResolver.insert(Notes.CONTENT_NOTE_URI, values);//将内容_笔记的URI插入到内容解决器
+ }
+ dialog.dismiss();//撤销对话框
+ }
+ });
+
+ if (TextUtils.isEmpty(etName.getText())) {//如果文件夹名称为空,则不能选择确定按钮
+ positive.setEnabled(false);
+ }
+ /**
+ * When the name edit text is null, disable the positive button
+ */
+ etName.addTextChangedListener(new TextWatcher() {//添加文本更改监听器,即判断文本更改状态
+ public void beforeTextChanged(CharSequence s, int start, int count, int after) {//文本更改之前(未完成)
+ // TODO Auto-generated method stub
+
+ }
+
+ public void onTextChanged(CharSequence s, int start, int before, int count) {//当前文本改变触发,
+ if (TextUtils.isEmpty(etName.getText())) {//文本为空确定按键不可用,不为空则可用
+ positive.setEnabled(false);
+ } else {
+ positive.setEnabled(true);
+ }
+ }
+
+ public void afterTextChanged(Editable s) {//文本修改之后(未完成)
+ // TODO Auto-generated method stub
+
+ }
+ });
+ }
+
+ @Override
+ public void onBackPressed() {//从文件夹,主界面退出的一些操作
+ switch (mState) {//判断当前状态
+ case SUB_FOLDER://从文件夹里退出,当前状态是子文件夹
+ mCurrentFolderId = Notes.ID_ROOT_FOLDER;//改变文件夹名称
+ mState = ListEditState.NOTE_LIST;//变为列表模式
+ startAsyncNotesListQuery();//对列表显示请求同步
+ mTitleBar.setVisibility(View.GONE);//将文件夹的标题设置不可见
+ break;
+ case CALL_RECORD_FOLDER://call_record_folder状态
+ mCurrentFolderId = Notes.ID_ROOT_FOLDER;
+ mState = ListEditState.NOTE_LIST;
+ mAddNewNote.setVisibility(View.VISIBLE);//新建便签设置为可见
+ mTitleBar.setVisibility(View.GONE);
+ startAsyncNotesListQuery();
+ break;
+ case NOTE_LIST://从主界面退出
+ super.onBackPressed();//调用父类退出方法
+ break;
+ default://其他情况直接break
+ break;
+ }
+ }
+
+ private void updateWidget(int appWidgetId, int appWidgetType) {//只有删除在桌面上的便签才运行,设置格式
+ Intent intent = new Intent(AppWidgetManager.ACTION_APPWIDGET_UPDATE);//动作:更新,创建intent,用于创建新活动
+ if (appWidgetType == Notes.TYPE_WIDGET_2X) {
+ intent.setClass(this, NoteWidgetProvider_2x.class);
+ } else if (appWidgetType == Notes.TYPE_WIDGET_4X) {
+ intent.setClass(this, NoteWidgetProvider_4x.class);
+ } else {
+ Log.e(TAG, "Unspported widget type");
+ return;
+ }
+
+ intent.putExtra(AppWidgetManager.EXTRA_APPWIDGET_IDS, new int[]{
+ appWidgetId
+ });//储存id的键值对
+
+ sendBroadcast(intent);//发送广播
+ setResult(RESULT_OK, intent);//返回给上一个活动数据
+ }
+
+ private final OnCreateContextMenuListener mFolderOnCreateContextMenuListener = new OnCreateContextMenuListener() {
+ public void onCreateContextMenu(ContextMenu menu, View v, ContextMenuInfo menuInfo) {//对添加文件操作的内容
+ if (mFocusNoteDataItem != null) {
+ menu.setHeaderTitle(mFocusNoteDataItem.getSnippet());
+ menu.add(0, MENU_FOLDER_VIEW, 0, R.string.menu_folder_view);
+ menu.add(0, MENU_FOLDER_DELETE, 0, R.string.menu_folder_delete);
+ menu.add(0, MENU_FOLDER_CHANGE_NAME, 0, R.string.menu_folder_change_name);
+ }
+ }
+ };
+
+ @Override
+ public void onContextMenuClosed(Menu menu) {//关闭文件夹的菜单
+ if (mNotesListView != null) {
+ mNotesListView.setOnCreateContextMenuListener(null);
+ }
+ super.onContextMenuClosed(menu);
+ }
+
+ @Override
+ public boolean onContextItemSelected(MenuItem item) {//对文件夹操作的实现
+ if (mFocusNoteDataItem == null) {
+ Log.e(TAG, "The long click data item is null");
+ return false;
+ }
+ switch (item.getItemId()) {
+ case MENU_FOLDER_VIEW:
+ openFolder(mFocusNoteDataItem);
+ break;
+ case MENU_FOLDER_DELETE:
+ AlertDialog.Builder builder = new AlertDialog.Builder(this);
+ builder.setTitle(getString(R.string.alert_title_delete));
+ builder.setIcon(android.R.drawable.ic_dialog_alert);
+ builder.setMessage(getString(R.string.alert_message_delete_folder));
+ builder.setPositiveButton(android.R.string.ok,
+ new DialogInterface.OnClickListener() {
+ public void onClick(DialogInterface dialog, int which) {
+ deleteFolder(mFocusNoteDataItem.getId());
+ }
+ });
+ builder.setNegativeButton(android.R.string.cancel, null);
+ builder.show();
+ break;
+ case MENU_FOLDER_CHANGE_NAME:
+ showCreateOrModifyFolderDialog(false);
+ break;
+ default:
+ break;
+ }
+
+ return true;
+ }
+ //mine 5
+ @Override
+ public boolean onPrepareOptionsMenu(Menu menu) {//准备菜单,根据不同的状态加载不同的菜单
+ menu.clear();//先把原先的菜单删除
+
+ if (mState == ListEditState.NOTE_LIST) {
+ getMenuInflater().inflate(R.menu.note_list, menu);
+ // set sync or sync_cancel
+ menu.findItem(R.id.menu_sync).setTitle(
+ GTaskSyncService.isSyncing() ? R.string.menu_sync_cancel : R.string.menu_sync);
+
+ } else if (mState == ListEditState.SUB_FOLDER) {
+ getMenuInflater().inflate(R.menu.sub_folder, menu);
+ } else if (mState == ListEditState.CALL_RECORD_FOLDER) {
+ getMenuInflater().inflate(R.menu.call_record_folder, menu);
+ } else {
+ Log.e(TAG, "Wrong state:" + mState);
+ }
+
+ return true;
+ }
+
+ @Override
+ public boolean onOptionsItemSelected(MenuItem item) {
+ switch (item.getItemId()) {//mine 14
+
+ case R.id.menu_new_folder: {
+ showCreateOrModifyFolderDialog(true);
+ break;
+ }
+ case R.id.menu_export_text: {
+ exportNoteToText();//输出到SD卡
+ break;
+ }
+ case R.id.menu_sync: {
+ if (isSyncMode()) {//开始同步
+ if (TextUtils.equals(item.getTitle(), getString(R.string.menu_sync))) {
+ GTaskSyncService.startSync(this);
+ } else {//取消同步
+ GTaskSyncService.cancelSync(this);
+ }
+ } else {//切换到设置活动界面
+ startPreferenceActivity();
+ }
+ break;
+ }
+ case R.id.menu_setting: {
+ startPreferenceActivity();
+ break;
+ }
+ case R.id.menu_new_note: {
+ showNoteType();
+ break;
+ }
+ case R.id.menu_search:
+ onSearchRequested();
+ break;
+ default:
+ break;
+ }
+ return true;
+ }
+
+ private void startSetting(){//mine 4
+ Intent intent = new Intent(NotesListActivity.this, GestureSetting.class);
+ this.startActivityForResult(intent,GESTURE_SETTING);
+ }
+ @Override
+ public boolean onSearchRequested() {//查找功能
+ startSearch(null, false, null /* appData */, false);//好像还没实现
+ return true;
+ }
+ public void showNoteType(){//mine 12
+ final String[] items = {"普通便签", "快速添加时间", "快速添加地址"};
+ AlertDialog.Builder alertBuilder = new AlertDialog.Builder(this);
+ alertBuilder.setTitle("选择创建的便签");
+ alertBuilder.setItems(items, new DialogInterface.OnClickListener() {
+ @Override
+ public void onClick(DialogInterface dialogInterface, int i) {
+ //对createNewNote方法进行了调用
+ // 参数i即使代表所选单选按钮的排列次序,也代表打开便签模板的类型
+ createNewNote(i);
+ Toast.makeText(NotesListActivity.this, items[i], Toast.LENGTH_SHORT).show();
+ alertDialog1.dismiss();
+ }
+ });
+ alertDialog1 = alertBuilder.create();
+ alertDialog1.show();
+ }
+ private void showNumberofNotes() {// mine 4
+ StringBuilder strbdr = new StringBuilder("");
+ strbdr.append("当前有 " + Integer.toString(mNotesListAdapter.retCount()) + " 个便签");
+ Toast.makeText(this, strbdr.toString(), Toast.LENGTH_LONG).show();
+ }
+
+ private void exportNoteToText() {//输出便签到SD卡
+ final BackupUtils backup = BackupUtils.getInstance(NotesListActivity.this);//备份笔记信息
+ new AsyncTask() {
+
+ @Override
+ protected Integer doInBackground(Void... unused) {
+ return backup.exportToText();
+ }//后台运行
+
+ @Override
+ protected void onPostExecute(Integer result) {
+ if (result == BackupUtils.STATE_SD_CARD_UNMOUONTED) {
+ AlertDialog.Builder builder = new AlertDialog.Builder(NotesListActivity.this);
+ builder.setTitle(NotesListActivity.this
+ .getString(R.string.failed_sdcard_export));
+ builder.setMessage(NotesListActivity.this
+ .getString(R.string.error_sdcard_unmounted));
+ builder.setPositiveButton(android.R.string.ok, null);
+ builder.show();
+ } else if (result == BackupUtils.STATE_SUCCESS) {
+ AlertDialog.Builder builder = new AlertDialog.Builder(NotesListActivity.this);
+ builder.setTitle(NotesListActivity.this
+ .getString(R.string.success_sdcard_export));
+ builder.setMessage(NotesListActivity.this.getString(
+ R.string.format_exported_file_location, backup
+ .getExportedTextFileName(), backup.getExportedTextFileDir()));
+ builder.setPositiveButton(android.R.string.ok, null);
+ builder.show();
+ } else if (result == BackupUtils.STATE_SYSTEM_ERROR) {
+ AlertDialog.Builder builder = new AlertDialog.Builder(NotesListActivity.this);
+ builder.setTitle(NotesListActivity.this
+ .getString(R.string.failed_sdcard_export));
+ builder.setMessage(NotesListActivity.this
+ .getString(R.string.error_sdcard_export));
+ builder.setPositiveButton(android.R.string.ok, null);
+ builder.show();
+ }
+ }
+
+ }.execute();
+ }
+
+ private boolean isSyncMode() {//判断是否在同步模式
+ return NotesPreferenceActivity.getSyncAccountName(this).trim().length() > 0;//查看NotePrefereActivity同步账户的名字的长度是否大于0,若大于,则为同步模式
+ }
+
+ private void startPreferenceActivity() {//切换到设置和同步界面
+ Activity from = getParent() != null ? getParent() : this;
+ Intent intent = new Intent(from, NotesPreferenceActivity.class);
+ from.startActivityIfNeeded(intent, -1);//此活动结束后不会通知原活动
+ }
+
+ private class OnListItemClickListener implements OnItemClickListener {//监听列表点击监听器,接口是OnItemClickListener
+
+ //position代表选中的便签项在视图中的索引
+ public void onItemClick(AdapterView> parent, View view, int position, long id) {//项目被点击的响应
+ if (view instanceof NotesListItem) {//判断view是否是NotesListItem的一个实例,如果是就获取他的项目信息装入item中
+ NoteItemData item = ((NotesListItem) view).getItemData();
+ if (mNotesListAdapter.isInChoiceMode()) {//如果目前正处在选择模式下
+ if (item.getType() == Notes.TYPE_NOTE) {//如果点到的item是便签
+ position = position - mNotesListView.getHeaderViewsCount();//减去头部视图的元素项,得到列表的元素索引值
+ mModeCallBack.onItemCheckedStateChanged(null, position, id,
+ !mNotesListAdapter.isSelectedItem(position));//改变对应索引的Item是否被选中的状态
+ }
+ return;
+ }
+
+ switch (mState) {//当前状态判断
+ case NOTE_LIST://当在主列表下
+ if (item.getType() == Notes.TYPE_FOLDER
+ || item.getType() == Notes.TYPE_SYSTEM) {
+ openFolder(item);//如果点到文件夹,就打开
+ } else if (item.getType() == Notes.TYPE_NOTE) {
+ testNode(item);// 有个判断
+
+ } else {
+ Log.e(TAG, "Wrong note type in NOTE_LIST");
+ }
+ break;
+ case SUB_FOLDER:
+ case CALL_RECORD_FOLDER://子文件夹下的情况
+ if (item.getType() == Notes.TYPE_NOTE) {
+ testNode(item);
+ } else {
+ Log.e(TAG, "Wrong note type in SUB_FOLDER");
+ }
+ break;
+ default:
+ break;
+ }
+ }
+ }
+
+ }
+ public void testNode(final NoteItemData item){//mine 56
+ if(item.getmPassWord().equals(""))//判断是否有密码,如果没有密码,那么item.getmPassWord()返回的值就是空字符串
+ {
+ openNode(item);
+ }
+ else{
+ final AlertDialog.Builder builder = new AlertDialog.Builder(this);//初始化对话框
+ View view = LayoutInflater.from(this).inflate(R.layout.dialog_pwd_confirm, null);//加载对话框的布局文件
+ final EditText etPwd = (EditText) view.findViewById(R.id.set_private_pwd_confirm);//初始化对话框里的文本对象
+ showSoftInput();//显示软键盘
+ builder.setPositiveButton(android.R.string.ok, null);//确定按钮
+ builder.setNegativeButton(android.R.string.cancel, new DialogInterface.OnClickListener() {
+ public void onClick(DialogInterface dialog, int which) {//取消按钮
+ hideSoftInput(etPwd);//隐藏软键盘
+ }
+ });
+ final Dialog dialog = builder.setView(view).show();//显示出来
+ final Button positive = (Button)dialog.findViewById(android.R.id.button1);//加载确定按钮布局文件
+ positive.setOnClickListener(new OnClickListener() {
+ public void onClick(View v) {//设置确定按钮的接收器
+ hideSoftInput(etPwd);//点击确定后收起软键盘
+ String Password = etPwd.getText().toString();//文本框里的输入值
+ if (!TextUtils.isEmpty(Password)) {//输入不为空
+ if(Password.equals(item.getmPassWord())){
+ openNode(item);
+ }
+ else {
+ Toast.makeText(getApplicationContext(),"密码错误",Toast.LENGTH_LONG).show();
+ }
+ }
+ dialog.dismiss();//撤销对话框
+
+ }
+
+ });
+ if (TextUtils.isEmpty(etPwd.getText())) {//如果文件夹名称为空,则不能选择确定按钮
+ positive.setEnabled(false);
+ }
+
+ etPwd.addTextChangedListener(new TextWatcher() {//添加文本更改监听器,即判断文本更改状态
+ public void beforeTextChanged(CharSequence s, int start, int count, int after) {//文本更改之前(未完成)
+ // TODO Auto-generated method stub
+ }
+
+ public void onTextChanged(CharSequence s, int start, int before, int count) {//当前文本改变触发,
+ if (TextUtils.isEmpty(etPwd.getText())) {//文本为空确定按键不可用,不为空则可用
+ positive.setEnabled(false);
+ } else {
+ positive.setEnabled(true);
+ }
+ }
+ public void afterTextChanged(Editable s) {//文本修改之后(未完成)
+ // TODO Auto-generated method stub
+ }
+ });
+ }
+ }
+ private void startQueryDestinationFolders() {//按下移动便签后,开始查找所有的文件夹
+ String selection = NoteColumns.TYPE + "=? AND " + NoteColumns.PARENT_ID + "<>? AND " + NoteColumns.ID + "<>?";
+ selection = (mState == ListEditState.NOTE_LIST) ? selection :
+ "(" + selection + ") OR (" + NoteColumns.ID + "=" + Notes.ID_ROOT_FOLDER + ")";
+
+ mBackgroundQueryHandler.startQuery(FOLDER_LIST_QUERY_TOKEN,
+ null,
+ Notes.CONTENT_NOTE_URI,
+ FoldersListAdapter.PROJECTION,
+ selection,
+ new String[]{
+ String.valueOf(Notes.TYPE_FOLDER),
+ String.valueOf(Notes.ID_TRASH_FOLER),
+ String.valueOf(mCurrentFolderId)
+ },
+ NoteColumns.MODIFIED_DATE + " DESC");
+ }
+
+ public boolean onItemLongClick(AdapterView> parent, View view, int position, long id) {
+ if (view instanceof NotesListItem) {//判断view是否是NotesListItem的一个实例,如果是就获取他的项目信息装入item中
+ mFocusNoteDataItem = ((NotesListItem) view).getItemData();//聚焦的Item对象
+ if (mFocusNoteDataItem.getType() == Notes.TYPE_NOTE && !mNotesListAdapter.isInChoiceMode()) {//如果对象是便签,并且不在选择模式下
+ if (mNotesListView.startActionMode(mModeCallBack) != null) {//开始对单个便签进行操作
+ mModeCallBack.onItemCheckedStateChanged(null, position, id, true);
+ mNotesListView.performHapticFeedback(HapticFeedbackConstants.LONG_PRESS);//执行长按动作触发震动反馈
+ } else {
+ Log.e(TAG, "startActionMode fails");
+ }
+ } else if (mFocusNoteDataItem.getType() == Notes.TYPE_FOLDER) {//如果长按对象是文件夹
+ mNotesListView.setOnCreateContextMenuListener(mFolderOnCreateContextMenuListener);//创建文件夹长按的监听器,创建对文件夹的菜单
+ }
+ }
+ return false;
+ }
+
+}
diff --git a/src/src/app/src/main/java/net/micode/notes/ui/NotesListAdapter.java b/src/src/app/src/main/java/net/micode/notes/ui/NotesListAdapter.java
new file mode 100644
index 0000000..618019e
--- /dev/null
+++ b/src/src/app/src/main/java/net/micode/notes/ui/NotesListAdapter.java
@@ -0,0 +1,204 @@
+/*
+ * Copyright (c) 2010-2011, The MiCode Open Source Community (www.micode.net)
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+
+package net.micode.notes.ui;
+
+import android.content.Context;
+import android.database.Cursor;
+import android.util.Log;
+import android.view.View;
+import android.view.ViewGroup;
+import android.widget.CursorAdapter;
+
+import net.micode.notes.data.Notes;
+
+import java.util.Collection;
+import java.util.HashMap;
+import java.util.HashSet;
+import java.util.Iterator;
+
+
+public class NotesListAdapter extends CursorAdapter {//类NotesListAdopter实现的是鼠标和编辑便签连接的桥梁,继承了光标配适器
+ private static final String TAG = "NotesListAdapter";//名称,一般用于输出日志文件
+ private Context mContext;//便签相关内容
+ private HashMap mSelectedIndex;//哈希表表示的便签是否勾选
+
+ private boolean mChoiceMode;//判断是否处于选择模式
+
+ private int mNotesCount;//便签数量
+ //返回便签总数量
+ public int retCount(){//mine 16
+ int NotesCount = mNotesCount;
+ int ItemCount = getCount();
+ for (int i = 0; i < ItemCount; i++) {
+ Cursor c = (Cursor) getItem(i);
+ if (c != null) {
+ //如果便签项是文件夹,则把文件夹下的便签也计入
+ if (NoteItemData.getNoteType(c) == Notes.TYPE_FOLDER) {
+ NoteItemData NoteItem = new NoteItemData(mContext, c);
+ NotesCount += NoteItem.getNotesCount();
+ }
+ } else {
+ Log.e(TAG, "Invalid cursor");
+ return -1;
+ }
+ }
+ return NotesCount;
+ }
+ public static class AppWidgetAttribute {//类里声明了桌面挂件widget的属性,包括编号和类型
+ public int widgetId;
+ public int widgetType;
+ };
+
+ public NotesListAdapter(Context context) {//以便签列表的context初始化便签列表配适器
+ super(context, null);
+ mSelectedIndex = new HashMap();//初始化哈希表
+ mContext = context;
+ mNotesCount = 0;//初始便签数为0
+ }
+
+ @Override
+ public View newView(Context context, Cursor cursor, ViewGroup parent) {
+ return new NotesListItem(context);//创建便签列表的数据项
+ }
+
+ @Override
+ public void bindView(View view, Context context, Cursor cursor) {//将已经存在的视图和光标指向的数据进行捆绑
+ if (view instanceof NotesListItem) {//如果视图是NotesListItem的一个实例
+ NoteItemData itemData = new NoteItemData(context, cursor);
+ ((NotesListItem) view).bind(context, itemData, mChoiceMode,//绑定光标指向的数据
+ isSelectedItem(cursor.getPosition()));
+ }
+ }
+
+ public void setCheckedItem(final int position, final boolean checked) {//设置勾选框
+ mSelectedIndex.put(position, checked);//添加便签和是否被选中的键值对
+ notifyDataSetChanged();//提醒数据已经改变
+ }
+
+ public boolean isInChoiceMode() {
+ return mChoiceMode;
+ }//判断是否处于选择模式中
+
+ public void setChoiceMode(boolean mode) {//设置模式,在选择模式和普通模式中切换
+ mSelectedIndex.clear();//将原先的勾选数据清空
+ mChoiceMode = mode;//设置模式
+ }
+
+ public void selectAll(boolean checked) {//全选操作
+ Cursor cursor = getCursor();
+ for (int i = 0; i < getCount(); i++) {
+ if (cursor.moveToPosition(i)) {
+ if (NoteItemData.getNoteType(cursor) == Notes.TYPE_NOTE) {//如果是便签,则选
+ setCheckedItem(i, checked);
+ }
+ }
+ }
+ }
+
+ public HashSet getSelectedItemIds() {//以哈希表形式返回被选中便签的id号
+ HashSet itemSet = new HashSet();
+ for (Integer position : mSelectedIndex.keySet()) {
+ if (mSelectedIndex.get(position) == true) {
+ Long id = getItemId(position);
+ if (id == Notes.ID_ROOT_FOLDER) {
+ Log.d(TAG, "Wrong item id, should not happen");
+ } else {
+ itemSet.add(id);
+ }
+ }
+ }
+
+ return itemSet;
+ }
+
+ public HashSet getSelectedWidget() {//已哈希表形式返回选中的桌面挂件
+ HashSet itemSet = new HashSet();
+ for (Integer position : mSelectedIndex.keySet()) {
+ if (mSelectedIndex.get(position) == true) {
+ Cursor c = (Cursor) getItem(position);
+ if (c != null) {
+ AppWidgetAttribute widget = new AppWidgetAttribute();
+ NoteItemData item = new NoteItemData(mContext, c);
+ widget.widgetId = item.getWidgetId();
+ widget.widgetType = item.getWidgetType();
+ itemSet.add(widget);
+ /**
+ * Don't close cursor here, only the adapter could close it
+ */
+ } else {
+ Log.e(TAG, "Invalid cursor");
+ return null;
+ }
+ }
+ }
+ return itemSet;
+ }
+
+ public int getSelectedCount() {//显示选中了几项
+ Collection values = mSelectedIndex.values();
+ if (null == values) {
+ return 0;
+ }
+ Iterator iter = values.iterator();
+ int count = 0;
+ while (iter.hasNext()) {
+ if (true == iter.next()) {
+ count++;
+ }
+ }
+ return count;
+ }
+
+ public boolean isAllSelected() {//是否全部选中
+ int checkedCount = getSelectedCount();
+ return (checkedCount != 0 && checkedCount == mNotesCount);
+ }
+
+ public boolean isSelectedItem(final int position) {//改变Item是否被选中的状态
+ if (null == mSelectedIndex.get(position)) {
+ return false;
+ }
+ return mSelectedIndex.get(position);
+ }
+
+ @Override
+ protected void onContentChanged() {//内容变动时调用calcNotesCount计算便签数量
+ super.onContentChanged();
+ calcNotesCount();
+ }
+
+ @Override
+ public void changeCursor(Cursor cursor) {//在activity光标发生局部变动的时候回调该函数计算便签的数量
+ super.changeCursor(cursor);
+ calcNotesCount();
+ }
+
+ private void calcNotesCount() {//计算当前界面便签的数量
+ mNotesCount = 0;
+ for (int i = 0; i < getCount(); i++) {
+ Cursor c = (Cursor) getItem(i);
+ if (c != null) {
+ if (NoteItemData.getNoteType(c) == Notes.TYPE_NOTE) {
+ mNotesCount++;
+ }
+ } else {
+ Log.e(TAG, "Invalid cursor");
+ return;
+ }
+ }
+ }
+}
diff --git a/src/src/app/src/main/java/net/micode/notes/ui/NotesListItem.java b/src/src/app/src/main/java/net/micode/notes/ui/NotesListItem.java
new file mode 100644
index 0000000..e6dc7f3
--- /dev/null
+++ b/src/src/app/src/main/java/net/micode/notes/ui/NotesListItem.java
@@ -0,0 +1,139 @@
+/*
+ * Copyright (c) 2010-2011, The MiCode Open Source Community (www.micode.net)
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+
+package net.micode.notes.ui;
+
+import android.content.Context;
+import android.text.format.DateUtils;
+import android.view.View;
+import android.widget.CheckBox;
+import android.widget.ImageView;
+import android.widget.LinearLayout;
+import android.widget.TextView;
+
+import net.micode.notes.R;
+import net.micode.notes.data.Notes;
+import net.micode.notes.tool.DataUtils;
+import net.micode.notes.tool.ResourceParser.NoteItemBgResources;
+//构建便签列表的各个项目的详细具体信息,如显示提醒标签的图标,设置列表项的背景颜色,继承线性列表,例如设置便签最后修改时间等
+//mine 12
+public class NotesListItem extends LinearLayout {
+ private ImageView mAlert;//提醒的图片视图
+ private TextView mTitle;//标题的文本视图
+ private TextView mTime;//最后修改的时间的文本视图
+ private TextView mCallName;//CallName的文本视图
+ private NoteItemData mItemData;//便签数据项
+ private CheckBox mCheckBox;//选择模式下,便签项前勾选的列表
+ private ImageView mKey;//提醒的图片视图
+
+ public NotesListItem(Context context) {//加载视图和对应的资源文件
+ super(context);
+ inflate(context, R.layout.note_item, this);
+ mAlert = (ImageView) findViewById(R.id.iv_alert_icon);
+ mTitle = (TextView) findViewById(R.id.tv_title);
+ mTime = (TextView) findViewById(R.id.tv_time);
+ mCallName = (TextView) findViewById(R.id.tv_name);
+ mCheckBox = (CheckBox) findViewById(android.R.id.checkbox);
+ mKey = (ImageView) findViewById(R.id.for_key);
+ }
+
+ public void bind(Context context, NoteItemData data, boolean choiceMode, boolean checked) {//对于当前列表的每一项,都需要绑定对于的checkBox
+ if (choiceMode && data.getType() == Notes.TYPE_NOTE) {//如果在选择模式下,并且对应的时间是便签项,则设置勾选项为可见
+ mCheckBox.setVisibility(View.VISIBLE);
+ mCheckBox.setChecked(checked);//设置是否处于选择模式
+ } else {
+ mCheckBox.setVisibility(View.GONE);
+ }
+
+ mItemData = data;
+ if (data.getId() == Notes.ID_CALL_RECORD_FOLDER) {//数据项对应的类型是CALL_RECORD_FOLDER
+ mCallName.setVisibility(View.GONE);//设置联系人名字不可见
+ mAlert.setVisibility(View.VISIBLE);//设置时间提醒图标可见
+ mTitle.setTextAppearance(context, R.style.TextAppearancePrimaryItem);//设置文本框内容
+ mTitle.setText(context.getString(R.string.call_record_folder_name)
+ + context.getString(R.string.format_folder_files_count, data.getNotesCount()));
+ mAlert.setImageResource(R.drawable.call_record);//设置提醒的图标
+ } else if (data.getParentId() == Notes.ID_CALL_RECORD_FOLDER) {//数据项的父文件夹对应的类型是CALL_RECORD_FOLDER
+ mCallName.setVisibility(View.VISIBLE);
+ mCallName.setText(data.getCallName());
+ mTitle.setTextAppearance(context,R.style.TextAppearanceSecondaryItem);
+ mTitle.setText(DataUtils.getFormattedSnippet(data.getSnippet()));//设置title的文本内容为便签内容的前面片段
+ if (data.hasAlert()) {//如果便签有提醒,则加载对应的图片
+ mAlert.setImageResource(R.drawable.clock);
+ mAlert.setVisibility(View.VISIBLE);
+ } else {
+ mAlert.setVisibility(View.GONE);
+ }
+ if(data.getType() == Notes.TYPE_NOTE && !(data.getmPassWord().equals("")) ){//如果便签为私密便签
+ mTitle.setText("[已加密]"+"密码提示:"+data.getmHint());//mine 10
+ mKey.setImageResource(R.drawable.key);
+ mKey.setVisibility(View.VISIBLE);
+ } else {
+ mKey.setVisibility(View.GONE);
+ }
+ } else {
+ mCallName.setVisibility(View.GONE);//设置联系人姓名不可见
+ mTitle.setTextAppearance(context, R.style.TextAppearancePrimaryItem);
+
+ if (data.getType() == Notes.TYPE_FOLDER) {//如果是数据项是文件夹
+ mTitle.setText(data.getSnippet()
+ + context.getString(R.string.format_folder_files_count,
+ data.getNotesCount()));//设置便签标题内容为便签的前面部分的内容+文件数+便签数
+ mAlert.setVisibility(View.GONE);//设置提醒不可见
+ mKey.setVisibility(View.GONE);//提前设置为gone
+ } else {
+ mTitle.setText(DataUtils.getFormattedSnippet(data.getSnippet()));//如果是便签,则设置便签标题内容为便签的前面部分的内容
+ if (data.hasAlert()) {//如果数据项是有提醒的便签,则显示相应的图片
+ mAlert.setImageResource(R.drawable.clock);
+ mAlert.setVisibility(View.VISIBLE);
+ } else {
+ mAlert.setVisibility(View.GONE);
+ }
+ if(data.getType() == Notes.TYPE_NOTE && !(data.getmPassWord().equals("")) ){
+ mTitle.setText("[已加密]"+"密码提示:"+data.getmHint());
+ mKey.setImageResource(R.drawable.key);
+ mKey.setVisibility(View.VISIBLE);
+ } else {
+ mKey.setVisibility(View.GONE);
+ }
+ }
+ }
+ mTime.setText(DateUtils.getRelativeTimeSpanString(data.getModifiedDate()));//设置最后一次改变的时间
+
+ setBackground(data);//设置数据项的背景
+ }
+
+ private void setBackground(NoteItemData data) {//所有的,每一个数据项,设置其背景,默认五种颜色
+ int id = data.getBgColorId();//获得数据项的背景颜色的索引值
+ if (data.getType() == Notes.TYPE_NOTE) {//如果是便签项,设置相应的背景资源
+ if (data.isSingle() || data.isOneFollowingFolder()) {//如果只有一个便签,或者文件夹下只有一个便签
+ setBackgroundResource(NoteItemBgResources.getNoteBgSingleRes(id));
+ } else if (data.isLast()) {//如果是最后一个便签
+ setBackgroundResource(NoteItemBgResources.getNoteBgLastRes(id));
+ } else if (data.isFirst() || data.isMultiFollowingFolder()) {//如果是第一个便签,或者是文件夹下有多个便签
+ setBackgroundResource(NoteItemBgResources.getNoteBgFirstRes(id));
+ } else {
+ setBackgroundResource(NoteItemBgResources.getNoteBgNormalRes(id));//一般情况
+ }
+ } else {
+ setBackgroundResource(NoteItemBgResources.getFolderBgRes());//设置文件夹的显示样式
+ }
+ }
+
+ public NoteItemData getItemData() {
+ return mItemData;
+ }
+}
diff --git a/src/src/app/src/main/java/net/micode/notes/ui/NotesPreferenceActivity.java b/src/src/app/src/main/java/net/micode/notes/ui/NotesPreferenceActivity.java
new file mode 100644
index 0000000..75d2256
--- /dev/null
+++ b/src/src/app/src/main/java/net/micode/notes/ui/NotesPreferenceActivity.java
@@ -0,0 +1,398 @@
+/*
+ * Copyright (c) 2010-2011, The MiCode Open Source Community (www.micode.net)
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+
+package net.micode.notes.ui;
+
+import android.accounts.Account;
+import android.accounts.AccountManager;
+import android.app.ActionBar;
+import android.app.AlertDialog;
+import android.content.BroadcastReceiver;
+import android.content.ContentValues;
+import android.content.Context;
+import android.content.DialogInterface;
+import android.content.Intent;
+import android.content.IntentFilter;
+import android.content.SharedPreferences;
+import android.gesture.Gesture;
+import android.gesture.GestureOverlayView;
+import android.gesture.Prediction;
+import android.os.Bundle;
+import android.preference.Preference;
+import android.preference.Preference.OnPreferenceClickListener;
+import android.preference.PreferenceActivity;
+import android.preference.PreferenceCategory;
+import android.text.TextUtils;
+import android.text.format.DateFormat;
+import android.view.GestureDetector;
+import android.view.LayoutInflater;
+import android.view.Menu;
+import android.view.MenuItem;
+import android.view.MotionEvent;
+import android.view.View;
+import android.widget.Button;
+import android.widget.TextView;
+import android.widget.Toast;
+
+import net.micode.notes.R;
+import net.micode.notes.data.Notes;
+import net.micode.notes.data.Notes.NoteColumns;
+import net.micode.notes.gtask.remote.GTaskSyncService;
+import net.micode.notes.tool.ScreenUtils;
+
+import java.util.ArrayList;
+
+//主要是用于登录账号;将便签的内容与Google Task上的数据进行同步;设置新建便签默认颜色随机等
+// 类:NotesPreferenceActivity,在小米便签中主要实现的是对背景颜色和字体大小的数据储存。
+// 继承了PreferenceActivity主要功能为对系统信息和配置进行自动保存的Activity
+public class NotesPreferenceActivity extends PreferenceActivity {
+ public static final String PREFERENCE_NAME = "notes_preferences";
+ //偏好的名称
+ public static final String PREFERENCE_SYNC_ACCOUNT_NAME = "pref_key_account_name";
+ //同步账户名称
+ public static final String PREFERENCE_LAST_SYNC_TIME = "pref_last_sync_time";
+ //最后同步的时间
+ public static final String PREFERENCE_SET_BG_COLOR_KEY = "pref_key_bg_random_appear";
+ //背景颜色
+ private static final String PREFERENCE_SYNC_ACCOUNT_KEY = "pref_sync_account_key";
+ //同步账户密码
+ private static final String AUTHORITIES_FILTER_KEY = "authorities";
+
+ private PreferenceCategory mAccountCategory;
+ //账户分组
+ private GTaskReceiver mReceiver;
+ //广播接收器
+ private Account[] mOriAccounts;
+ //账户列表
+ private boolean mHasAddedAccount;
+ //是否添加账户
+ @Override
+ protected void onCreate(Bundle icicle) {//加载布局,初始化广播接收器
+ super.onCreate(icicle);
+ //Action Bar取代了传统的tittle bar和menu,在程序运行中一直置于顶部
+ /* using the app icon for navigation */
+ getActionBar().setDisplayHomeAsUpEnabled(true);//设置左上方的退出按键,一个左向的箭头
+
+ addPreferencesFromResource(R.xml.preferences);//从资源里添加布局文件,包括随机设置便签背景颜色
+ mAccountCategory = (PreferenceCategory) findPreference(PREFERENCE_SYNC_ACCOUNT_KEY);//设置的布局配置
+ mReceiver = new GTaskReceiver();//广播接收器
+ IntentFilter filter = new IntentFilter();//过滤其他的action
+ filter.addAction(GTaskSyncService.GTASK_SERVICE_BROADCAST_NAME);//点击“同步账号”按钮时,它就会通知后台处于监听状态的gtask同步账号服务,
+ registerReceiver(mReceiver, filter);//动态注册接收器
+
+ mOriAccounts = null;
+ View header = LayoutInflater.from(this).inflate(R.layout.settings_header, null);//头部(立即同步的按键)的资源布局
+ getListView().addHeaderView(header, null, true);
+ }
+
+ @Override
+ protected void onResume() {//活动重启,由不可见变为可见,自动如果用户添加了一个新账户,则同步账户,
+ super.onResume();
+
+ // need to set sync account automatically if user has added a new
+ // account
+ if (mHasAddedAccount) {
+ Account[] accounts = getGoogleAccounts();
+ if (mOriAccounts != null && accounts.length > mOriAccounts.length) {
+ for (Account accountNew : accounts) {
+ boolean found = false;
+ for (Account accountOld : mOriAccounts) {
+ if (TextUtils.equals(accountOld.name, accountNew.name)) {
+ found = true;
+ break;
+ }
+ }
+ if (!found) {
+ setSyncAccount(accountNew.name);
+ break;
+ }
+ }
+ }
+ }
+
+ refreshUI();//刷新界面
+ }
+
+ @Override
+ protected void onDestroy() {//取消广播器的监听
+ if (mReceiver != null) {
+ unregisterReceiver(mReceiver);
+ }
+ super.onDestroy();
+ }
+
+ private void loadAccountPreference() {//按下同步后,选择账户的设置
+ mAccountCategory.removeAll();//先清除之前的所有偏好元素,包括布局等
+
+ Preference accountPref = new Preference(this);//同步账户的按钮
+ final String defaultAccount = getSyncAccountName(this);
+ accountPref.setTitle(getString(R.string.preferences_account_title));
+ accountPref.setSummary(getString(R.string.preferences_account_summary));//(类似副标题)
+ accountPref.setOnPreferenceClickListener(new OnPreferenceClickListener() {
+ public boolean onPreferenceClick(Preference preference) {//设置preference的的监听器
+ if (!GTaskSyncService.isSyncing()) {//不在同步状态下
+ if (TextUtils.isEmpty(defaultAccount)) {//如果没有默认的账户
+ // the first time to set account
+ showSelectAccountAlertDialog();//显示选择账户的对话框
+ } else {
+ // if the account has already been set, we need to promp
+ // user about the risk
+ showChangeAccountConfirmAlertDialog();//显示需要改变账户的对话框
+ }
+ } else {//正在同步,不能切换同步的账号
+ Toast.makeText(NotesPreferenceActivity.this,
+ R.string.preferences_toast_cannot_change_account, Toast.LENGTH_SHORT)
+ .show();
+ }
+ return true;
+ }
+ });
+
+ mAccountCategory.addPreference(accountPref);//加载抓胡的偏好元素
+ }
+
+ private void loadSyncButton() {//加载同步按键
+ Button syncButton = (Button) findViewById(R.id.preference_sync_button);//同步按键的布局
+ TextView lastSyncTimeView = (TextView) findViewById(R.id.prefenerece_sync_status_textview);//最后一次同步的时间
+
+ // set button state
+ if (GTaskSyncService.isSyncing()) {//如果在同步状态下,则按钮设置未取消同步
+ syncButton.setText(getString(R.string.preferences_button_sync_cancel));
+ syncButton.setOnClickListener(new View.OnClickListener() {
+ public void onClick(View v) {//点击后执行取消同步方法
+ GTaskSyncService.cancelSync(NotesPreferenceActivity.this);
+ }
+ });
+ } else {//否则立即同步,按钮设置立即同步
+ syncButton.setText(getString(R.string.preferences_button_sync_immediately));
+ syncButton.setOnClickListener(new View.OnClickListener() {
+ public void onClick(View v) {
+ GTaskSyncService.startSync(NotesPreferenceActivity.this);
+ }
+ });
+ }
+ syncButton.setEnabled(!TextUtils.isEmpty(getSyncAccountName(this)));//如果没有账户,则不可选立即同步的按键
+
+ // set last sync time
+ if (GTaskSyncService.isSyncing()) {//如果正在同步则读取正在同步的进度,否则显示最后同步的时间
+ lastSyncTimeView.setText(GTaskSyncService.getProgressString());
+ lastSyncTimeView.setVisibility(View.VISIBLE);
+ } else {
+ long lastSyncTime = getLastSyncTime(this);
+ if (lastSyncTime != 0) {
+ lastSyncTimeView.setText(getString(R.string.preferences_last_sync_time,
+ DateFormat.format(getString(R.string.preferences_last_sync_time_format),
+ lastSyncTime)));
+ lastSyncTimeView.setVisibility(View.VISIBLE);
+ } else {
+ lastSyncTimeView.setVisibility(View.GONE);
+ }
+ }
+ }
+
+ private void refreshUI() {//刷新界面,包括偏好元素和按键
+ loadAccountPreference();
+ loadSyncButton();
+ }
+
+ private void showSelectAccountAlertDialog() {//设置选择账户的对话框
+ AlertDialog.Builder dialogBuilder = new AlertDialog.Builder(this);
+
+ View titleView = LayoutInflater.from(this).inflate(R.layout.account_dialog_title, null);
+ TextView titleTextView = (TextView) titleView.findViewById(R.id.account_dialog_title);
+ titleTextView.setText(getString(R.string.preferences_dialog_select_account_title));
+ TextView subtitleTextView = (TextView) titleView.findViewById(R.id.account_dialog_subtitle);
+ subtitleTextView.setText(getString(R.string.preferences_dialog_select_account_tips));
+
+ dialogBuilder.setCustomTitle(titleView);
+ dialogBuilder.setPositiveButton(null, null);//无确定的按钮
+
+ Account[] accounts = getGoogleAccounts();//获得谷歌账户
+ String defAccount = getSyncAccountName(this);//默认的庄户
+
+ mOriAccounts = accounts;
+ mHasAddedAccount = false;
+
+ if (accounts.length > 0) {//如果有谷歌账户,则显示所有账户的名称,并设置为选项
+ CharSequence[] items = new CharSequence[accounts.length];
+ final CharSequence[] itemMapping = items;
+ int checkedItem = -1;
+ int index = 0;
+ for (Account account : accounts) {
+ if (TextUtils.equals(account.name, defAccount)) {
+ checkedItem = index;
+ }
+ items[index++] = account.name;
+ }
+ dialogBuilder.setSingleChoiceItems(items, checkedItem,//设置为选项
+ new DialogInterface.OnClickListener() {
+ public void onClick(DialogInterface dialog, int which) {
+ setSyncAccount(itemMapping[which].toString());//点击则开始设置同步账户
+ dialog.dismiss();
+ refreshUI();
+ }
+ });
+ }
+
+ View addAccountView = LayoutInflater.from(this).inflate(R.layout.add_account_text, null);
+ dialogBuilder.setView(addAccountView);//设置添加账户的视图
+
+ final AlertDialog dialog = dialogBuilder.show();
+ addAccountView.setOnClickListener(new View.OnClickListener() {//并设置监听器
+ public void onClick(View v) {//当点击添加账户时,创建新活动,因为请求码是-1,所以此活动结束后不会反馈给源活动
+ mHasAddedAccount = true;//设置为true,表示添加了账户
+ Intent intent = new Intent("android.settings.ADD_ACCOUNT_SETTINGS");
+ intent.putExtra(AUTHORITIES_FILTER_KEY, new String[] {//放入AUTHORITIES_FILTER_KEY对应gmail-ls的键值对
+ "gmail-ls"
+ });
+ startActivityForResult(intent, -1);
+ dialog.dismiss();//清楚对话框
+ }
+ });
+ }
+
+ private void showChangeAccountConfirmAlertDialog() {//设置改变账户的对话框
+ AlertDialog.Builder dialogBuilder = new AlertDialog.Builder(this);
+ //加载一些布局,设置一些语句
+ View titleView = LayoutInflater.from(this).inflate(R.layout.account_dialog_title, null);
+ TextView titleTextView = (TextView) titleView.findViewById(R.id.account_dialog_title);
+ titleTextView.setText(getString(R.string.preferences_dialog_change_account_title,
+ getSyncAccountName(this)));
+ TextView subtitleTextView = (TextView) titleView.findViewById(R.id.account_dialog_subtitle);
+ subtitleTextView.setText(getString(R.string.preferences_dialog_change_account_warn_msg));
+ dialogBuilder.setCustomTitle(titleView);
+
+ CharSequence[] menuItemArray = new CharSequence[] {//三种模式:改变同步账户,删除同步账户,取消
+ getString(R.string.preferences_menu_change_account),
+ getString(R.string.preferences_menu_remove_account),
+ getString(R.string.preferences_menu_cancel)
+ };
+ dialogBuilder.setItems(menuItemArray, new DialogInterface.OnClickListener() {
+ public void onClick(DialogInterface dialog, int which) {
+ if (which == 0) {
+ showSelectAccountAlertDialog();//如果是改变同步账户,则显示可选择的账户
+ } else if (which == 1) {//删除同步账户
+ removeSyncAccount();
+ refreshUI();//刷新界面
+ }
+ }
+ });
+ dialogBuilder.show();
+ }
+
+ private Account[] getGoogleAccounts() {//得到谷歌账户信息
+ AccountManager accountManager = AccountManager.get(this);
+ return accountManager.getAccountsByType("com.google");//通过google方式返回账户
+ }
+
+ private void setSyncAccount(String account) {//设置同步账户
+ if (!getSyncAccountName(this).equals(account)) {//如果该账号不在同步账号列表中
+ SharedPreferences settings = getSharedPreferences(PREFERENCE_NAME, Context.MODE_PRIVATE);
+ SharedPreferences.Editor editor = settings.edit();
+ if (account != null) {//编辑共享的首选项
+ editor.putString(PREFERENCE_SYNC_ACCOUNT_NAME, account);
+ } else {
+ editor.putString(PREFERENCE_SYNC_ACCOUNT_NAME, "");
+ }
+ editor.commit();//提交修改的数据
+
+ // clean up last sync time
+ setLastSyncTime(this, 0);//清楚最后同步的时间
+
+ // clean up local gtask related info
+ new Thread(new Runnable() {//清楚本地的gtask关联的信息
+ public void run() {
+ ContentValues values = new ContentValues();
+ values.put(NoteColumns.GTASK_ID, "");
+ values.put(NoteColumns.SYNC_ID, 0);
+ getContentResolver().update(Notes.CONTENT_NOTE_URI, values, null, null);
+ }
+ }).start();
+
+ Toast.makeText(NotesPreferenceActivity.this,
+ getString(R.string.preferences_toast_success_set_accout, account),//提示已经设置同步账户成功
+ Toast.LENGTH_SHORT).show();
+ }
+ }
+
+ private void removeSyncAccount() {//移除同步账户
+ SharedPreferences settings = getSharedPreferences(PREFERENCE_NAME, Context.MODE_PRIVATE);
+ SharedPreferences.Editor editor = settings.edit();
+ if (settings.contains(PREFERENCE_SYNC_ACCOUNT_NAME)) {
+ editor.remove(PREFERENCE_SYNC_ACCOUNT_NAME);
+ }
+ if (settings.contains(PREFERENCE_LAST_SYNC_TIME)) {
+ editor.remove(PREFERENCE_LAST_SYNC_TIME);
+ }
+ editor.commit();
+
+ // clean up local gtask related info
+ new Thread(new Runnable() {//清除本地与gtask有关的信息
+ public void run() {
+ ContentValues values = new ContentValues();
+ values.put(NoteColumns.GTASK_ID, "");
+ values.put(NoteColumns.SYNC_ID, 0);
+ getContentResolver().update(Notes.CONTENT_NOTE_URI, values, null, null);
+ }
+ }).start();
+ }
+
+ public static String getSyncAccountName(Context context) {//得到同步账户的名称
+ SharedPreferences settings = context.getSharedPreferences(PREFERENCE_NAME,
+ Context.MODE_PRIVATE);
+ return settings.getString(PREFERENCE_SYNC_ACCOUNT_NAME, "");
+ }
+
+ public static void setLastSyncTime(Context context, long time) {//设置最后同步的时间
+ SharedPreferences settings = context.getSharedPreferences(PREFERENCE_NAME,
+ Context.MODE_PRIVATE);
+ SharedPreferences.Editor editor = settings.edit();
+ editor.putLong(PREFERENCE_LAST_SYNC_TIME, time);//输入键值对
+ editor.commit();//提交编辑内容
+ }
+
+ public static long getLastSyncTime(Context context) {//得到最后同步的时间
+ SharedPreferences settings = context.getSharedPreferences(PREFERENCE_NAME,
+ Context.MODE_PRIVATE);
+ return settings.getLong(PREFERENCE_LAST_SYNC_TIME, 0);
+ }
+
+ private class GTaskReceiver extends BroadcastReceiver {//广播接收器
+
+ @Override
+ public void onReceive(Context context, Intent intent) {
+ refreshUI();//接受到广播就刷新界面
+ if (intent.getBooleanExtra(GTaskSyncService.GTASK_SERVICE_BROADCAST_IS_SYNCING, false)) {//如果在同步状态,改变同步按钮显示的文本
+ TextView syncStatus = (TextView) findViewById(R.id.prefenerece_sync_status_textview);
+ syncStatus.setText(intent
+ .getStringExtra(GTaskSyncService.GTASK_SERVICE_BROADCAST_PROGRESS_MSG));
+ }
+
+ }
+ }
+
+ public boolean onOptionsItemSelected(MenuItem item) {
+ switch (item.getItemId()) {
+ case android.R.id.home://返回主界面
+ Intent intent = new Intent(this, NotesListActivity.class);
+ intent.addFlags(Intent.FLAG_ACTIVITY_CLEAR_TOP);
+ startActivity(intent);//创建活动
+ return true;
+ default:
+ return false;
+ }
+ }
+}
diff --git a/src/src/app/src/main/java/net/micode/notes/widget/NoteWidgetProvider.java b/src/src/app/src/main/java/net/micode/notes/widget/NoteWidgetProvider.java
new file mode 100644
index 0000000..95a4875
--- /dev/null
+++ b/src/src/app/src/main/java/net/micode/notes/widget/NoteWidgetProvider.java
@@ -0,0 +1,132 @@
+/*
+ * Copyright (c) 2010-2011, The MiCode Open Source Community (www.micode.net)
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+
+package net.micode.notes.widget;
+import android.app.PendingIntent;
+import android.appwidget.AppWidgetManager;
+import android.appwidget.AppWidgetProvider;
+import android.content.ContentValues;
+import android.content.Context;
+import android.content.Intent;
+import android.database.Cursor;
+import android.util.Log;
+import android.widget.RemoteViews;
+
+import net.micode.notes.R;
+import net.micode.notes.data.Notes;
+import net.micode.notes.data.Notes.NoteColumns;
+import net.micode.notes.tool.ResourceParser;
+import net.micode.notes.ui.NoteEditActivity;
+import net.micode.notes.ui.NotesListActivity;
+
+public abstract class NoteWidgetProvider extends AppWidgetProvider {
+ public static final String [] PROJECTION = new String [] {
+ NoteColumns.ID,
+ NoteColumns.BG_COLOR_ID,
+ NoteColumns.SNIPPET
+ };
+
+ public static final int COLUMN_ID = 0;
+ public static final int COLUMN_BG_COLOR_ID = 1;
+ public static final int COLUMN_SNIPPET = 2;
+
+ private static final String TAG = "NoteWidgetProvider";
+
+ @Override
+ public void onDeleted(Context context, int[] appWidgetIds) {
+ ContentValues values = new ContentValues();
+ values.put(NoteColumns.WIDGET_ID, AppWidgetManager.INVALID_APPWIDGET_ID);
+ for (int i = 0; i < appWidgetIds.length; i++) {
+ context.getContentResolver().update(Notes.CONTENT_NOTE_URI,
+ values,
+ NoteColumns.WIDGET_ID + "=?",
+ new String[] { String.valueOf(appWidgetIds[i])});
+ }
+ }
+
+ private Cursor getNoteWidgetInfo(Context context, int widgetId) {
+ return context.getContentResolver().query(Notes.CONTENT_NOTE_URI,
+ PROJECTION,
+ NoteColumns.WIDGET_ID + "=? AND " + NoteColumns.PARENT_ID + "<>?",
+ new String[] { String.valueOf(widgetId), String.valueOf(Notes.ID_TRASH_FOLER) },
+ null);
+ }
+
+ protected void update(Context context, AppWidgetManager appWidgetManager, int[] appWidgetIds) {//小部件时调用
+ update(context, appWidgetManager, appWidgetIds, false);
+ }
+
+ private void update(Context context, AppWidgetManager appWidgetManager, int[] appWidgetIds,
+ boolean privacyMode) {
+ for (int i = 0; i < appWidgetIds.length; i++) {//扫描所有的桌面挂件
+ if (appWidgetIds[i] != AppWidgetManager.INVALID_APPWIDGET_ID) {
+ int bgId = ResourceParser.getDefaultBgId(context);
+ String snippet = "";
+ Intent intent = new Intent(context, NoteEditActivity.class);
+ intent.setFlags(Intent.FLAG_ACTIVITY_SINGLE_TOP);//下面有关intent的操作,都是准备传递数据
+ intent.putExtra(Notes.INTENT_EXTRA_WIDGET_ID, appWidgetIds[i]);
+ intent.putExtra(Notes.INTENT_EXTRA_WIDGET_TYPE, getWidgetType());
+
+ Cursor c = getNoteWidgetInfo(context, appWidgetIds[i]);
+ if (c != null && c.moveToFirst()) {//判断桌面挂件是否关联便签
+ if (c.getCount() > 1) {
+ Log.e(TAG, "Multiple message with same widget id:" + appWidgetIds[i]);
+ c.close();
+ return;
+ }//
+ snippet = c.getString(COLUMN_SNIPPET);
+ bgId = c.getInt(COLUMN_BG_COLOR_ID);
+ intent.putExtra(Intent.EXTRA_UID, c.getLong(COLUMN_ID));
+ intent.setAction(Intent.ACTION_VIEW);
+ } else {//没有关联
+ snippet = context.getResources().getString(R.string.widget_havenot_content);
+ intent.setAction(Intent.ACTION_INSERT_OR_EDIT);
+ }
+
+ if (c != null) {
+ c.close();
+ }
+
+ RemoteViews rv = new RemoteViews(context.getPackageName(), getLayoutId());
+ rv.setImageViewResource(R.id.widget_bg_image, getBgResourceId(bgId));
+ intent.putExtra(Notes.INTENT_EXTRA_BACKGROUND_ID, bgId);
+ /**
+ * Generate the pending intent to start host for the widget
+ */
+ PendingIntent pendingIntent = null;
+ if (privacyMode) {
+ rv.setTextViewText(R.id.widget_text,
+ context.getString(R.string.widget_under_visit_mode));
+ pendingIntent = PendingIntent.getActivity(context, appWidgetIds[i], new Intent(
+ context, NotesListActivity.class), PendingIntent.FLAG_UPDATE_CURRENT);
+ } else {
+ rv.setTextViewText(R.id.widget_text, snippet);
+ pendingIntent = PendingIntent.getActivity(context, appWidgetIds[i], intent,
+ PendingIntent.FLAG_UPDATE_CURRENT);
+ }
+
+ rv.setOnClickPendingIntent(R.id.widget_text, pendingIntent);
+ appWidgetManager.updateAppWidget(appWidgetIds[i], rv);
+ }
+ }
+ }
+
+ protected abstract int getBgResourceId(int bgId);
+
+ protected abstract int getLayoutId();
+
+ protected abstract int getWidgetType();
+}
diff --git a/src/src/app/src/main/java/net/micode/notes/widget/NoteWidgetProvider_2x.java b/src/src/app/src/main/java/net/micode/notes/widget/NoteWidgetProvider_2x.java
new file mode 100644
index 0000000..9c8fb4e
--- /dev/null
+++ b/src/src/app/src/main/java/net/micode/notes/widget/NoteWidgetProvider_2x.java
@@ -0,0 +1,47 @@
+/*
+ * Copyright (c) 2010-2011, The MiCode Open Source Community (www.micode.net)
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+
+package net.micode.notes.widget;
+
+import android.appwidget.AppWidgetManager;
+import android.content.Context;
+
+import net.micode.notes.R;
+import net.micode.notes.data.Notes;
+import net.micode.notes.tool.ResourceParser;
+
+
+public class NoteWidgetProvider_2x extends NoteWidgetProvider {
+ @Override
+ public void onUpdate(Context context, AppWidgetManager appWidgetManager, int[] appWidgetIds) {//添加时调用
+ super.update(context, appWidgetManager, appWidgetIds);
+ }
+
+ @Override
+ protected int getLayoutId() {
+ return R.layout.widget_2x;
+ }
+
+ @Override
+ protected int getBgResourceId(int bgId) {
+ return ResourceParser.WidgetBgResources.getWidget2xBgResource(bgId);
+ }
+
+ @Override
+ protected int getWidgetType() {
+ return Notes.TYPE_WIDGET_2X;
+ }
+}
diff --git a/src/src/app/src/main/java/net/micode/notes/widget/NoteWidgetProvider_4x.java b/src/src/app/src/main/java/net/micode/notes/widget/NoteWidgetProvider_4x.java
new file mode 100644
index 0000000..c12a02e
--- /dev/null
+++ b/src/src/app/src/main/java/net/micode/notes/widget/NoteWidgetProvider_4x.java
@@ -0,0 +1,46 @@
+/*
+ * Copyright (c) 2010-2011, The MiCode Open Source Community (www.micode.net)
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+
+package net.micode.notes.widget;
+
+import android.appwidget.AppWidgetManager;
+import android.content.Context;
+
+import net.micode.notes.R;
+import net.micode.notes.data.Notes;
+import net.micode.notes.tool.ResourceParser;
+
+
+public class NoteWidgetProvider_4x extends NoteWidgetProvider {
+ @Override
+ public void onUpdate(Context context, AppWidgetManager appWidgetManager, int[] appWidgetIds) {
+ super.update(context, appWidgetManager, appWidgetIds);
+ }
+
+ protected int getLayoutId() {
+ return R.layout.widget_4x;
+ }
+
+ @Override
+ protected int getBgResourceId(int bgId) {
+ return ResourceParser.WidgetBgResources.getWidget4xBgResource(bgId);
+ }
+
+ @Override
+ protected int getWidgetType() {
+ return Notes.TYPE_WIDGET_4X;
+ }
+}
diff --git a/src/src/app/src/main/res/color/primary_text_dark.xml b/src/src/app/src/main/res/color/primary_text_dark.xml
new file mode 100644
index 0000000..8ad98e3
--- /dev/null
+++ b/src/src/app/src/main/res/color/primary_text_dark.xml
@@ -0,0 +1,22 @@
+
+
+
+
+
+
+
+
+
\ No newline at end of file
diff --git a/src/src/app/src/main/res/color/secondary_text_dark.xml b/src/src/app/src/main/res/color/secondary_text_dark.xml
new file mode 100644
index 0000000..9cf8a1a
--- /dev/null
+++ b/src/src/app/src/main/res/color/secondary_text_dark.xml
@@ -0,0 +1,20 @@
+
+
+
+
+
+
+
\ No newline at end of file
diff --git a/src/src/app/src/main/res/drawable-hdpi/bg_btn_set_color.png b/src/src/app/src/main/res/drawable-hdpi/bg_btn_set_color.png
new file mode 100644
index 0000000..5eb5d44
Binary files /dev/null and b/src/src/app/src/main/res/drawable-hdpi/bg_btn_set_color.png differ
diff --git a/src/src/app/src/main/res/drawable-hdpi/bg_color_btn_mask.png b/src/src/app/src/main/res/drawable-hdpi/bg_color_btn_mask.png
new file mode 100644
index 0000000..100db77
Binary files /dev/null and b/src/src/app/src/main/res/drawable-hdpi/bg_color_btn_mask.png differ
diff --git a/src/src/app/src/main/res/drawable-hdpi/call_record.png b/src/src/app/src/main/res/drawable-hdpi/call_record.png
new file mode 100644
index 0000000..fb88ca4
Binary files /dev/null and b/src/src/app/src/main/res/drawable-hdpi/call_record.png differ
diff --git a/src/src/app/src/main/res/drawable-hdpi/clock.png b/src/src/app/src/main/res/drawable-hdpi/clock.png
new file mode 100644
index 0000000..5f2ae9a
Binary files /dev/null and b/src/src/app/src/main/res/drawable-hdpi/clock.png differ
diff --git a/src/src/app/src/main/res/drawable-hdpi/delete.png b/src/src/app/src/main/res/drawable-hdpi/delete.png
new file mode 100644
index 0000000..643de3e
Binary files /dev/null and b/src/src/app/src/main/res/drawable-hdpi/delete.png differ
diff --git a/src/src/app/src/main/res/drawable-hdpi/dropdown_icon.9.png b/src/src/app/src/main/res/drawable-hdpi/dropdown_icon.9.png
new file mode 100644
index 0000000..5525025
Binary files /dev/null and b/src/src/app/src/main/res/drawable-hdpi/dropdown_icon.9.png differ
diff --git a/src/src/app/src/main/res/drawable-hdpi/edit_blue.9.png b/src/src/app/src/main/res/drawable-hdpi/edit_blue.9.png
new file mode 100644
index 0000000..55a1856
Binary files /dev/null and b/src/src/app/src/main/res/drawable-hdpi/edit_blue.9.png differ
diff --git a/src/src/app/src/main/res/drawable-hdpi/edit_green.9.png b/src/src/app/src/main/res/drawable-hdpi/edit_green.9.png
new file mode 100644
index 0000000..2cb2d60
Binary files /dev/null and b/src/src/app/src/main/res/drawable-hdpi/edit_green.9.png differ
diff --git a/src/src/app/src/main/res/drawable-hdpi/edit_red.9.png b/src/src/app/src/main/res/drawable-hdpi/edit_red.9.png
new file mode 100644
index 0000000..bae944a
Binary files /dev/null and b/src/src/app/src/main/res/drawable-hdpi/edit_red.9.png differ
diff --git a/src/src/app/src/main/res/drawable-hdpi/edit_title_blue.9.png b/src/src/app/src/main/res/drawable-hdpi/edit_title_blue.9.png
new file mode 100644
index 0000000..96e6092
Binary files /dev/null and b/src/src/app/src/main/res/drawable-hdpi/edit_title_blue.9.png differ
diff --git a/src/src/app/src/main/res/drawable-hdpi/edit_title_green.9.png b/src/src/app/src/main/res/drawable-hdpi/edit_title_green.9.png
new file mode 100644
index 0000000..08d8644
Binary files /dev/null and b/src/src/app/src/main/res/drawable-hdpi/edit_title_green.9.png differ
diff --git a/src/src/app/src/main/res/drawable-hdpi/edit_title_red.9.png b/src/src/app/src/main/res/drawable-hdpi/edit_title_red.9.png
new file mode 100644
index 0000000..9c430e5
Binary files /dev/null and b/src/src/app/src/main/res/drawable-hdpi/edit_title_red.9.png differ
diff --git a/src/src/app/src/main/res/drawable-hdpi/edit_title_white.9.png b/src/src/app/src/main/res/drawable-hdpi/edit_title_white.9.png
new file mode 100644
index 0000000..19e8d95
Binary files /dev/null and b/src/src/app/src/main/res/drawable-hdpi/edit_title_white.9.png differ
diff --git a/src/src/app/src/main/res/drawable-hdpi/edit_title_yellow.9.png b/src/src/app/src/main/res/drawable-hdpi/edit_title_yellow.9.png
new file mode 100644
index 0000000..bf8f580
Binary files /dev/null and b/src/src/app/src/main/res/drawable-hdpi/edit_title_yellow.9.png differ
diff --git a/src/src/app/src/main/res/drawable-hdpi/edit_white.9.png b/src/src/app/src/main/res/drawable-hdpi/edit_white.9.png
new file mode 100644
index 0000000..918f7a6
Binary files /dev/null and b/src/src/app/src/main/res/drawable-hdpi/edit_white.9.png differ
diff --git a/src/src/app/src/main/res/drawable-hdpi/edit_yellow.9.png b/src/src/app/src/main/res/drawable-hdpi/edit_yellow.9.png
new file mode 100644
index 0000000..10cb642
Binary files /dev/null and b/src/src/app/src/main/res/drawable-hdpi/edit_yellow.9.png differ
diff --git a/src/src/app/src/main/res/drawable-hdpi/font_large.png b/src/src/app/src/main/res/drawable-hdpi/font_large.png
new file mode 100644
index 0000000..78cf2e6
Binary files /dev/null and b/src/src/app/src/main/res/drawable-hdpi/font_large.png differ
diff --git a/src/src/app/src/main/res/drawable-hdpi/font_normal.png b/src/src/app/src/main/res/drawable-hdpi/font_normal.png
new file mode 100644
index 0000000..9de7ced
Binary files /dev/null and b/src/src/app/src/main/res/drawable-hdpi/font_normal.png differ
diff --git a/src/src/app/src/main/res/drawable-hdpi/font_size_selector_bg.9.png b/src/src/app/src/main/res/drawable-hdpi/font_size_selector_bg.9.png
new file mode 100644
index 0000000..be8e64c
Binary files /dev/null and b/src/src/app/src/main/res/drawable-hdpi/font_size_selector_bg.9.png differ
diff --git a/src/src/app/src/main/res/drawable-hdpi/font_small.png b/src/src/app/src/main/res/drawable-hdpi/font_small.png
new file mode 100644
index 0000000..d3ff104
Binary files /dev/null and b/src/src/app/src/main/res/drawable-hdpi/font_small.png differ
diff --git a/src/src/app/src/main/res/drawable-hdpi/font_super.png b/src/src/app/src/main/res/drawable-hdpi/font_super.png
new file mode 100644
index 0000000..85b13a1
Binary files /dev/null and b/src/src/app/src/main/res/drawable-hdpi/font_super.png differ
diff --git a/src/src/app/src/main/res/drawable-hdpi/huaban.PNG b/src/src/app/src/main/res/drawable-hdpi/huaban.PNG
new file mode 100644
index 0000000..b22d341
Binary files /dev/null and b/src/src/app/src/main/res/drawable-hdpi/huaban.PNG differ
diff --git a/src/src/app/src/main/res/drawable-hdpi/icon_app.png b/src/src/app/src/main/res/drawable-hdpi/icon_app.png
new file mode 100644
index 0000000..418aadc
Binary files /dev/null and b/src/src/app/src/main/res/drawable-hdpi/icon_app.png differ
diff --git a/src/src/app/src/main/res/drawable-hdpi/key.png b/src/src/app/src/main/res/drawable-hdpi/key.png
new file mode 100644
index 0000000..6081559
Binary files /dev/null and b/src/src/app/src/main/res/drawable-hdpi/key.png differ
diff --git a/src/src/app/src/main/res/drawable-hdpi/list_background.png b/src/src/app/src/main/res/drawable-hdpi/list_background.png
new file mode 100644
index 0000000..dc70f53
Binary files /dev/null and b/src/src/app/src/main/res/drawable-hdpi/list_background.png differ
diff --git a/src/src/app/src/main/res/drawable-hdpi/list_blue_down.9.png b/src/src/app/src/main/res/drawable-hdpi/list_blue_down.9.png
new file mode 100644
index 0000000..b88eebf
Binary files /dev/null and b/src/src/app/src/main/res/drawable-hdpi/list_blue_down.9.png differ
diff --git a/src/src/app/src/main/res/drawable-hdpi/list_blue_middle.9.png b/src/src/app/src/main/res/drawable-hdpi/list_blue_middle.9.png
new file mode 100644
index 0000000..96b1c8b
Binary files /dev/null and b/src/src/app/src/main/res/drawable-hdpi/list_blue_middle.9.png differ
diff --git a/src/src/app/src/main/res/drawable-hdpi/list_blue_single.9.png b/src/src/app/src/main/res/drawable-hdpi/list_blue_single.9.png
new file mode 100644
index 0000000..d7e7206
Binary files /dev/null and b/src/src/app/src/main/res/drawable-hdpi/list_blue_single.9.png differ
diff --git a/src/src/app/src/main/res/drawable-hdpi/list_blue_up.9.png b/src/src/app/src/main/res/drawable-hdpi/list_blue_up.9.png
new file mode 100644
index 0000000..632e88c
Binary files /dev/null and b/src/src/app/src/main/res/drawable-hdpi/list_blue_up.9.png differ
diff --git a/src/src/app/src/main/res/drawable-hdpi/list_folder.9.png b/src/src/app/src/main/res/drawable-hdpi/list_folder.9.png
new file mode 100644
index 0000000..829f61b
Binary files /dev/null and b/src/src/app/src/main/res/drawable-hdpi/list_folder.9.png differ
diff --git a/src/src/app/src/main/res/drawable-hdpi/list_footer_bg.9.png b/src/src/app/src/main/res/drawable-hdpi/list_footer_bg.9.png
new file mode 100644
index 0000000..5325c25
Binary files /dev/null and b/src/src/app/src/main/res/drawable-hdpi/list_footer_bg.9.png differ
diff --git a/src/src/app/src/main/res/drawable-hdpi/list_green_down.9.png b/src/src/app/src/main/res/drawable-hdpi/list_green_down.9.png
new file mode 100644
index 0000000..64a39d9
Binary files /dev/null and b/src/src/app/src/main/res/drawable-hdpi/list_green_down.9.png differ
diff --git a/src/src/app/src/main/res/drawable-hdpi/list_green_middle.9.png b/src/src/app/src/main/res/drawable-hdpi/list_green_middle.9.png
new file mode 100644
index 0000000..897325a
Binary files /dev/null and b/src/src/app/src/main/res/drawable-hdpi/list_green_middle.9.png differ
diff --git a/src/src/app/src/main/res/drawable-hdpi/list_green_single.9.png b/src/src/app/src/main/res/drawable-hdpi/list_green_single.9.png
new file mode 100644
index 0000000..c83405f
Binary files /dev/null and b/src/src/app/src/main/res/drawable-hdpi/list_green_single.9.png differ
diff --git a/src/src/app/src/main/res/drawable-hdpi/list_green_up.9.png b/src/src/app/src/main/res/drawable-hdpi/list_green_up.9.png
new file mode 100644
index 0000000..141f9e1
Binary files /dev/null and b/src/src/app/src/main/res/drawable-hdpi/list_green_up.9.png differ
diff --git a/src/src/app/src/main/res/drawable-hdpi/list_red_down.9.png b/src/src/app/src/main/res/drawable-hdpi/list_red_down.9.png
new file mode 100644
index 0000000..4224309
Binary files /dev/null and b/src/src/app/src/main/res/drawable-hdpi/list_red_down.9.png differ
diff --git a/src/src/app/src/main/res/drawable-hdpi/list_red_middle.9.png b/src/src/app/src/main/res/drawable-hdpi/list_red_middle.9.png
new file mode 100644
index 0000000..9988f17
Binary files /dev/null and b/src/src/app/src/main/res/drawable-hdpi/list_red_middle.9.png differ
diff --git a/src/src/app/src/main/res/drawable-hdpi/list_red_single.9.png b/src/src/app/src/main/res/drawable-hdpi/list_red_single.9.png
new file mode 100644
index 0000000..587c348
Binary files /dev/null and b/src/src/app/src/main/res/drawable-hdpi/list_red_single.9.png differ
diff --git a/src/src/app/src/main/res/drawable-hdpi/list_red_up.9.png b/src/src/app/src/main/res/drawable-hdpi/list_red_up.9.png
new file mode 100644
index 0000000..46b4757
Binary files /dev/null and b/src/src/app/src/main/res/drawable-hdpi/list_red_up.9.png differ
diff --git a/src/src/app/src/main/res/drawable-hdpi/list_white_down.9.png b/src/src/app/src/main/res/drawable-hdpi/list_white_down.9.png
new file mode 100644
index 0000000..29f9d8c
Binary files /dev/null and b/src/src/app/src/main/res/drawable-hdpi/list_white_down.9.png differ
diff --git a/src/src/app/src/main/res/drawable-hdpi/list_white_middle.9.png b/src/src/app/src/main/res/drawable-hdpi/list_white_middle.9.png
new file mode 100644
index 0000000..77a4ab4
Binary files /dev/null and b/src/src/app/src/main/res/drawable-hdpi/list_white_middle.9.png differ
diff --git a/src/src/app/src/main/res/drawable-hdpi/list_white_single.9.png b/src/src/app/src/main/res/drawable-hdpi/list_white_single.9.png
new file mode 100644
index 0000000..3e79189
Binary files /dev/null and b/src/src/app/src/main/res/drawable-hdpi/list_white_single.9.png differ
diff --git a/src/src/app/src/main/res/drawable-hdpi/list_white_up.9.png b/src/src/app/src/main/res/drawable-hdpi/list_white_up.9.png
new file mode 100644
index 0000000..e23cd5c
Binary files /dev/null and b/src/src/app/src/main/res/drawable-hdpi/list_white_up.9.png differ
diff --git a/src/src/app/src/main/res/drawable-hdpi/list_yellow_down.9.png b/src/src/app/src/main/res/drawable-hdpi/list_yellow_down.9.png
new file mode 100644
index 0000000..31cfc1e
Binary files /dev/null and b/src/src/app/src/main/res/drawable-hdpi/list_yellow_down.9.png differ
diff --git a/src/src/app/src/main/res/drawable-hdpi/list_yellow_middle.9.png b/src/src/app/src/main/res/drawable-hdpi/list_yellow_middle.9.png
new file mode 100644
index 0000000..b6549b2
Binary files /dev/null and b/src/src/app/src/main/res/drawable-hdpi/list_yellow_middle.9.png differ
diff --git a/src/src/app/src/main/res/drawable-hdpi/list_yellow_single.9.png b/src/src/app/src/main/res/drawable-hdpi/list_yellow_single.9.png
new file mode 100644
index 0000000..3faf507
Binary files /dev/null and b/src/src/app/src/main/res/drawable-hdpi/list_yellow_single.9.png differ
diff --git a/src/src/app/src/main/res/drawable-hdpi/list_yellow_up.9.png b/src/src/app/src/main/res/drawable-hdpi/list_yellow_up.9.png
new file mode 100644
index 0000000..4ae791c
Binary files /dev/null and b/src/src/app/src/main/res/drawable-hdpi/list_yellow_up.9.png differ
diff --git a/src/src/app/src/main/res/drawable-hdpi/menu_delete.png b/src/src/app/src/main/res/drawable-hdpi/menu_delete.png
new file mode 100644
index 0000000..ccdfc4b
Binary files /dev/null and b/src/src/app/src/main/res/drawable-hdpi/menu_delete.png differ
diff --git a/src/src/app/src/main/res/drawable-hdpi/menu_move.png b/src/src/app/src/main/res/drawable-hdpi/menu_move.png
new file mode 100644
index 0000000..1140b71
Binary files /dev/null and b/src/src/app/src/main/res/drawable-hdpi/menu_move.png differ
diff --git a/src/src/app/src/main/res/drawable-hdpi/new_note_normal.png b/src/src/app/src/main/res/drawable-hdpi/new_note_normal.png
new file mode 100644
index 0000000..e24e0d1
Binary files /dev/null and b/src/src/app/src/main/res/drawable-hdpi/new_note_normal.png differ
diff --git a/src/src/app/src/main/res/drawable-hdpi/new_note_pressed.png b/src/src/app/src/main/res/drawable-hdpi/new_note_pressed.png
new file mode 100644
index 0000000..c748936
Binary files /dev/null and b/src/src/app/src/main/res/drawable-hdpi/new_note_pressed.png differ
diff --git a/src/src/app/src/main/res/drawable-hdpi/note_edit_color_selector_panel.png b/src/src/app/src/main/res/drawable-hdpi/note_edit_color_selector_panel.png
new file mode 100644
index 0000000..fc49552
Binary files /dev/null and b/src/src/app/src/main/res/drawable-hdpi/note_edit_color_selector_panel.png differ
diff --git a/src/src/app/src/main/res/drawable-hdpi/notification.png b/src/src/app/src/main/res/drawable-hdpi/notification.png
new file mode 100644
index 0000000..b13ab4a
Binary files /dev/null and b/src/src/app/src/main/res/drawable-hdpi/notification.png differ
diff --git a/src/src/app/src/main/res/drawable-hdpi/search_result.png b/src/src/app/src/main/res/drawable-hdpi/search_result.png
new file mode 100644
index 0000000..ff2befd
Binary files /dev/null and b/src/src/app/src/main/res/drawable-hdpi/search_result.png differ
diff --git a/src/src/app/src/main/res/drawable-hdpi/selected.png b/src/src/app/src/main/res/drawable-hdpi/selected.png
new file mode 100644
index 0000000..b889bef
Binary files /dev/null and b/src/src/app/src/main/res/drawable-hdpi/selected.png differ
diff --git a/src/src/app/src/main/res/drawable-hdpi/title_alert.png b/src/src/app/src/main/res/drawable-hdpi/title_alert.png
new file mode 100644
index 0000000..544ee9c
Binary files /dev/null and b/src/src/app/src/main/res/drawable-hdpi/title_alert.png differ
diff --git a/src/src/app/src/main/res/drawable-hdpi/title_bar_bg.9.png b/src/src/app/src/main/res/drawable-hdpi/title_bar_bg.9.png
new file mode 100644
index 0000000..eb6bff0
Binary files /dev/null and b/src/src/app/src/main/res/drawable-hdpi/title_bar_bg.9.png differ
diff --git a/src/src/app/src/main/res/drawable-hdpi/widget_2x_blue.png b/src/src/app/src/main/res/drawable-hdpi/widget_2x_blue.png
new file mode 100644
index 0000000..a1707f4
Binary files /dev/null and b/src/src/app/src/main/res/drawable-hdpi/widget_2x_blue.png differ
diff --git a/src/src/app/src/main/res/drawable-hdpi/widget_2x_green.png b/src/src/app/src/main/res/drawable-hdpi/widget_2x_green.png
new file mode 100644
index 0000000..f86886c
Binary files /dev/null and b/src/src/app/src/main/res/drawable-hdpi/widget_2x_green.png differ
diff --git a/src/src/app/src/main/res/drawable-hdpi/widget_2x_red.png b/src/src/app/src/main/res/drawable-hdpi/widget_2x_red.png
new file mode 100644
index 0000000..0e66c29
Binary files /dev/null and b/src/src/app/src/main/res/drawable-hdpi/widget_2x_red.png differ
diff --git a/src/src/app/src/main/res/drawable-hdpi/widget_2x_white.png b/src/src/app/src/main/res/drawable-hdpi/widget_2x_white.png
new file mode 100644
index 0000000..5f0619a
Binary files /dev/null and b/src/src/app/src/main/res/drawable-hdpi/widget_2x_white.png differ
diff --git a/src/src/app/src/main/res/drawable-hdpi/widget_2x_yellow.png b/src/src/app/src/main/res/drawable-hdpi/widget_2x_yellow.png
new file mode 100644
index 0000000..12d1c2b
Binary files /dev/null and b/src/src/app/src/main/res/drawable-hdpi/widget_2x_yellow.png differ
diff --git a/src/src/app/src/main/res/drawable-hdpi/widget_4x_blue.png b/src/src/app/src/main/res/drawable-hdpi/widget_4x_blue.png
new file mode 100644
index 0000000..9183738
Binary files /dev/null and b/src/src/app/src/main/res/drawable-hdpi/widget_4x_blue.png differ
diff --git a/src/src/app/src/main/res/drawable-hdpi/widget_4x_green.png b/src/src/app/src/main/res/drawable-hdpi/widget_4x_green.png
new file mode 100644
index 0000000..fa8b452
Binary files /dev/null and b/src/src/app/src/main/res/drawable-hdpi/widget_4x_green.png differ
diff --git a/src/src/app/src/main/res/drawable-hdpi/widget_4x_red.png b/src/src/app/src/main/res/drawable-hdpi/widget_4x_red.png
new file mode 100644
index 0000000..62de074
Binary files /dev/null and b/src/src/app/src/main/res/drawable-hdpi/widget_4x_red.png differ
diff --git a/src/src/app/src/main/res/drawable-hdpi/widget_4x_white.png b/src/src/app/src/main/res/drawable-hdpi/widget_4x_white.png
new file mode 100644
index 0000000..a37d67c
Binary files /dev/null and b/src/src/app/src/main/res/drawable-hdpi/widget_4x_white.png differ
diff --git a/src/src/app/src/main/res/drawable-hdpi/widget_4x_yellow.png b/src/src/app/src/main/res/drawable-hdpi/widget_4x_yellow.png
new file mode 100644
index 0000000..d7c5fa4
Binary files /dev/null and b/src/src/app/src/main/res/drawable-hdpi/widget_4x_yellow.png differ
diff --git a/src/src/app/src/main/res/drawable/new_note.xml b/src/src/app/src/main/res/drawable/new_note.xml
new file mode 100644
index 0000000..2154ebc
--- /dev/null
+++ b/src/src/app/src/main/res/drawable/new_note.xml
@@ -0,0 +1,23 @@
+
+
+
+
+
+
+
+
diff --git a/src/src/app/src/main/res/layout/account_dialog_title.xml b/src/src/app/src/main/res/layout/account_dialog_title.xml
new file mode 100644
index 0000000..7717112
--- /dev/null
+++ b/src/src/app/src/main/res/layout/account_dialog_title.xml
@@ -0,0 +1,43 @@
+
+
+
+
+
+
+
+
+
+
+
\ No newline at end of file
diff --git a/src/src/app/src/main/res/layout/add_account_text.xml b/src/src/app/src/main/res/layout/add_account_text.xml
new file mode 100644
index 0000000..c799178
--- /dev/null
+++ b/src/src/app/src/main/res/layout/add_account_text.xml
@@ -0,0 +1,32 @@
+
+
+
+
+
+
+
+
\ No newline at end of file
diff --git a/src/src/app/src/main/res/layout/datetime_picker.xml b/src/src/app/src/main/res/layout/datetime_picker.xml
new file mode 100644
index 0000000..f10d592
--- /dev/null
+++ b/src/src/app/src/main/res/layout/datetime_picker.xml
@@ -0,0 +1,56 @@
+
+
+
+
+
+
+
+
+
+
+
+
\ No newline at end of file
diff --git a/src/src/app/src/main/res/layout/dialog_edit_text.xml b/src/src/app/src/main/res/layout/dialog_edit_text.xml
new file mode 100644
index 0000000..361b39a
--- /dev/null
+++ b/src/src/app/src/main/res/layout/dialog_edit_text.xml
@@ -0,0 +1,23 @@
+
+
+
+
+
\ No newline at end of file
diff --git a/src/src/app/src/main/res/layout/dialog_pwd.xml b/src/src/app/src/main/res/layout/dialog_pwd.xml
new file mode 100644
index 0000000..f61235f
--- /dev/null
+++ b/src/src/app/src/main/res/layout/dialog_pwd.xml
@@ -0,0 +1,33 @@
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
\ No newline at end of file
diff --git a/src/src/app/src/main/res/layout/dialog_pwd_confirm.xml b/src/src/app/src/main/res/layout/dialog_pwd_confirm.xml
new file mode 100644
index 0000000..946b583
--- /dev/null
+++ b/src/src/app/src/main/res/layout/dialog_pwd_confirm.xml
@@ -0,0 +1,20 @@
+
+
+
+
+
+
+
+
+
\ No newline at end of file
diff --git a/src/src/app/src/main/res/layout/dialog_save.xml b/src/src/app/src/main/res/layout/dialog_save.xml
new file mode 100644
index 0000000..311b472
--- /dev/null
+++ b/src/src/app/src/main/res/layout/dialog_save.xml
@@ -0,0 +1,50 @@
+
+
+
+
+
+
+
+
+
+
+
+
+
+
\ No newline at end of file
diff --git a/src/src/app/src/main/res/layout/folder_list_item.xml b/src/src/app/src/main/res/layout/folder_list_item.xml
new file mode 100644
index 0000000..77e8148
--- /dev/null
+++ b/src/src/app/src/main/res/layout/folder_list_item.xml
@@ -0,0 +1,29 @@
+
+
+
+
+
+
+
+
\ No newline at end of file
diff --git a/src/src/app/src/main/res/layout/gesture_setting.xml b/src/src/app/src/main/res/layout/gesture_setting.xml
new file mode 100644
index 0000000..df978b6
--- /dev/null
+++ b/src/src/app/src/main/res/layout/gesture_setting.xml
@@ -0,0 +1,18 @@
+
+
+
+
+
\ No newline at end of file
diff --git a/src/src/app/src/main/res/layout/myboard.xml b/src/src/app/src/main/res/layout/myboard.xml
new file mode 100644
index 0000000..5f142c1
--- /dev/null
+++ b/src/src/app/src/main/res/layout/myboard.xml
@@ -0,0 +1,51 @@
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
\ No newline at end of file
diff --git a/src/src/app/src/main/res/layout/note_edit.xml b/src/src/app/src/main/res/layout/note_edit.xml
new file mode 100644
index 0000000..f1c738b
--- /dev/null
+++ b/src/src/app/src/main/res/layout/note_edit.xml
@@ -0,0 +1,407 @@
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
diff --git a/src/src/app/src/main/res/layout/note_edit_list_item.xml b/src/src/app/src/main/res/layout/note_edit_list_item.xml
new file mode 100644
index 0000000..a885f9c
--- /dev/null
+++ b/src/src/app/src/main/res/layout/note_edit_list_item.xml
@@ -0,0 +1,39 @@
+
+
+
+
+
+
+
+
+
+
diff --git a/src/src/app/src/main/res/layout/note_item.xml b/src/src/app/src/main/res/layout/note_item.xml
new file mode 100644
index 0000000..d78350f
--- /dev/null
+++ b/src/src/app/src/main/res/layout/note_item.xml
@@ -0,0 +1,83 @@
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
diff --git a/src/src/app/src/main/res/layout/note_list.xml b/src/src/app/src/main/res/layout/note_list.xml
new file mode 100644
index 0000000..377801d
--- /dev/null
+++ b/src/src/app/src/main/res/layout/note_list.xml
@@ -0,0 +1,72 @@
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
diff --git a/src/src/app/src/main/res/layout/note_list_dropdown_menu.xml b/src/src/app/src/main/res/layout/note_list_dropdown_menu.xml
new file mode 100644
index 0000000..3fa271d
--- /dev/null
+++ b/src/src/app/src/main/res/layout/note_list_dropdown_menu.xml
@@ -0,0 +1,32 @@
+
+
+
+
+
+
+
+
\ No newline at end of file
diff --git a/src/src/app/src/main/res/layout/note_list_footer.xml b/src/src/app/src/main/res/layout/note_list_footer.xml
new file mode 100644
index 0000000..5ca7b22
--- /dev/null
+++ b/src/src/app/src/main/res/layout/note_list_footer.xml
@@ -0,0 +1,24 @@
+
+
+
+
+
\ No newline at end of file
diff --git a/src/src/app/src/main/res/layout/settings_header.xml b/src/src/app/src/main/res/layout/settings_header.xml
new file mode 100644
index 0000000..5eb8c50
--- /dev/null
+++ b/src/src/app/src/main/res/layout/settings_header.xml
@@ -0,0 +1,41 @@
+
+
+
+
+
+
+
+
+
+
+
\ No newline at end of file
diff --git a/src/src/app/src/main/res/layout/widget_2x.xml b/src/src/app/src/main/res/layout/widget_2x.xml
new file mode 100644
index 0000000..55970ce
--- /dev/null
+++ b/src/src/app/src/main/res/layout/widget_2x.xml
@@ -0,0 +1,37 @@
+
+
+
+
+
+
+
+
diff --git a/src/src/app/src/main/res/layout/widget_4x.xml b/src/src/app/src/main/res/layout/widget_4x.xml
new file mode 100644
index 0000000..dc9bb51
--- /dev/null
+++ b/src/src/app/src/main/res/layout/widget_4x.xml
@@ -0,0 +1,39 @@
+
+
+
+
+
+
+
+
+
+
diff --git a/src/src/app/src/main/res/menu/call_note_edit.xml b/src/src/app/src/main/res/menu/call_note_edit.xml
new file mode 100644
index 0000000..02c0528
--- /dev/null
+++ b/src/src/app/src/main/res/menu/call_note_edit.xml
@@ -0,0 +1,48 @@
+
+
+
+
+
diff --git a/src/src/app/src/main/res/menu/call_record_folder.xml b/src/src/app/src/main/res/menu/call_record_folder.xml
new file mode 100644
index 0000000..c664346
--- /dev/null
+++ b/src/src/app/src/main/res/menu/call_record_folder.xml
@@ -0,0 +1,23 @@
+
+
+
+
+
diff --git a/src/src/app/src/main/res/menu/note_edit.xml b/src/src/app/src/main/res/menu/note_edit.xml
new file mode 100644
index 0000000..da40979
--- /dev/null
+++ b/src/src/app/src/main/res/menu/note_edit.xml
@@ -0,0 +1,58 @@
+
+
+
+
+
\ No newline at end of file
diff --git a/src/src/app/src/main/res/menu/note_list.xml b/src/src/app/src/main/res/menu/note_list.xml
new file mode 100644
index 0000000..ff28bf4
--- /dev/null
+++ b/src/src/app/src/main/res/menu/note_list.xml
@@ -0,0 +1,40 @@
+
+
+
+
+
diff --git a/src/src/app/src/main/res/menu/note_list_dropdown.xml b/src/src/app/src/main/res/menu/note_list_dropdown.xml
new file mode 100644
index 0000000..7cbaadc
--- /dev/null
+++ b/src/src/app/src/main/res/menu/note_list_dropdown.xml
@@ -0,0 +1,20 @@
+
+
+
+
+
\ No newline at end of file
diff --git a/src/src/app/src/main/res/menu/note_list_options.xml b/src/src/app/src/main/res/menu/note_list_options.xml
new file mode 100644
index 0000000..daac008
--- /dev/null
+++ b/src/src/app/src/main/res/menu/note_list_options.xml
@@ -0,0 +1,31 @@
+
+
+
+
+
\ No newline at end of file
diff --git a/src/src/app/src/main/res/menu/sub_folder.xml b/src/src/app/src/main/res/menu/sub_folder.xml
new file mode 100644
index 0000000..b00de26
--- /dev/null
+++ b/src/src/app/src/main/res/menu/sub_folder.xml
@@ -0,0 +1,24 @@
+
+
+
+
+
\ No newline at end of file
diff --git a/src/src/app/src/main/res/raw-zh-rCN/contact.txt b/src/src/app/src/main/res/raw-zh-rCN/contact.txt
new file mode 100644
index 0000000..b12b1fa
--- /dev/null
+++ b/src/src/app/src/main/res/raw-zh-rCN/contact.txt
@@ -0,0 +1,8 @@
+联系人姓名:
+年龄:
+性别:
+生日:
+关系:
+地址:
+qq号码:
+微信号码:
diff --git a/src/src/app/src/main/res/raw-zh-rCN/event.txt b/src/src/app/src/main/res/raw-zh-rCN/event.txt
new file mode 100644
index 0000000..273368c
--- /dev/null
+++ b/src/src/app/src/main/res/raw-zh-rCN/event.txt
@@ -0,0 +1 @@
+时间:
diff --git a/src/src/app/src/main/res/raw-zh-rCN/gestures.txt b/src/src/app/src/main/res/raw-zh-rCN/gestures.txt
new file mode 100644
index 0000000..564059f
Binary files /dev/null and b/src/src/app/src/main/res/raw-zh-rCN/gestures.txt differ
diff --git a/src/src/app/src/main/res/raw-zh-rCN/introduction b/src/src/app/src/main/res/raw-zh-rCN/introduction
new file mode 100644
index 0000000..e76397a
--- /dev/null
+++ b/src/src/app/src/main/res/raw-zh-rCN/introduction
@@ -0,0 +1,9 @@
+欢迎使用MIUI便签!
+
+ 无论从软件中直接添加,还是从桌面拖出widget,MIUI便签能让你快速建立和保存便签;
+
+ 除了调整文字大小、便签背景、文件夹等基础功能外,你会发现MIUI便签也提供了清单模式、便签提醒、软件加密、导出到SD卡、同步google task的高级功能,让你的生活记录更加美好和安全;
+
+ 这是来自9年后的编辑,你可以在知士荟上和众多dalao讨论如何在9年后根据开源代码改进小米便签,增强它的功能
+
+ 来分享你的使用体验和开发思路吧:http://www.learnerhub.net/
diff --git a/src/src/app/src/main/res/raw-zh-rCN/passwd.txt b/src/src/app/src/main/res/raw-zh-rCN/passwd.txt
new file mode 100644
index 0000000..14f9f2e
--- /dev/null
+++ b/src/src/app/src/main/res/raw-zh-rCN/passwd.txt
@@ -0,0 +1,5 @@
+账户所属平台:
+昵称:
+账号:
+密码:
+安保问题答案:
diff --git a/src/src/app/src/main/res/raw/contact.txt b/src/src/app/src/main/res/raw/contact.txt
new file mode 100644
index 0000000..be66f01
--- /dev/null
+++ b/src/src/app/src/main/res/raw/contact.txt
@@ -0,0 +1,9 @@
+联系人姓名:
+年龄:
+性别:
+生日:
+关系:
+地址:
+qq号码:
+微信号码:
+
diff --git a/src/src/app/src/main/res/raw/event.txt b/src/src/app/src/main/res/raw/event.txt
new file mode 100644
index 0000000..273368c
--- /dev/null
+++ b/src/src/app/src/main/res/raw/event.txt
@@ -0,0 +1 @@
+时间:
diff --git a/src/src/app/src/main/res/raw/gestures.txt b/src/src/app/src/main/res/raw/gestures.txt
new file mode 100644
index 0000000..564059f
Binary files /dev/null and b/src/src/app/src/main/res/raw/gestures.txt differ
diff --git a/src/src/app/src/main/res/raw/introduction b/src/src/app/src/main/res/raw/introduction
new file mode 100644
index 0000000..269cf7b
--- /dev/null
+++ b/src/src/app/src/main/res/raw/introduction
@@ -0,0 +1 @@
+Welcome to use MIUI notes!
\ No newline at end of file
diff --git a/src/src/app/src/main/res/raw/passwd.txt b/src/src/app/src/main/res/raw/passwd.txt
new file mode 100644
index 0000000..14f9f2e
--- /dev/null
+++ b/src/src/app/src/main/res/raw/passwd.txt
@@ -0,0 +1,5 @@
+账户所属平台:
+昵称:
+账号:
+密码:
+安保问题答案:
diff --git a/src/src/app/src/main/res/values-zh-rCN/arrays.xml b/src/src/app/src/main/res/values-zh-rCN/arrays.xml
new file mode 100644
index 0000000..a092386
--- /dev/null
+++ b/src/src/app/src/main/res/values-zh-rCN/arrays.xml
@@ -0,0 +1,23 @@
+
+
+
+
+
+
+ 短信
+ 邮件
+
+
\ No newline at end of file
diff --git a/src/src/app/src/main/res/values-zh-rCN/strings.xml b/src/src/app/src/main/res/values-zh-rCN/strings.xml
new file mode 100644
index 0000000..db0b55f
--- /dev/null
+++ b/src/src/app/src/main/res/values-zh-rCN/strings.xml
@@ -0,0 +1,139 @@
+
+
+
+
+
+
+
+ 设置为隐私便签
+ 显示目前便签数量
+ 撤销隐私便签
+ 输入隐私密码
+ 插入图片
+ 打开相机
+ 手绘
+ 采用自定义手势
+ 采用默认手势
+
+
+ 便签
+ 便签2x2
+ 便签4x4
+ 没有关联内容,点击新建便签。
+ 访客模式下,便签内容不可见
+ ...
+ 新建便签
+ 成功删除提醒
+ 创建提醒
+ 已过期
+ yyyyMMdd
+ MM月dd日 kk:mm
+ 知道了
+ 查看
+ 呼叫电话
+ 发送邮件
+ 浏览网页
+ 打开地图
+
+ 新建文件夹
+ 导出文本
+ 同步
+ 取消同步
+ 设置
+ 搜索
+ 删除
+ 移动到文件夹
+ 选中了 %d 项
+ 没有选中项,操作无效
+ 全选
+ 取消全选
+ 文字大小
+ 小
+ 正常
+ 大
+ 超大
+ 进入清单模式
+ 退出清单模式
+ 查看文件夹
+ 刪除文件夹
+ 修改文件夹名称
+ 文件夹 %1$s 已存在,请重新命名
+ 分享
+ 发送到桌面
+ 提醒我
+ 删除提醒
+ 选择文件夹
+ 上一级文件夹
+ 已添加到桌面
+ 删除
+ 确认要删除所选的 %d 条便签吗?
+ 确认要删除该条便签吗?
+ 确认删除文件夹及所包含的便签吗?
+ 已将所选 %1$d 条便签移到 %2$s 文件夹
+
+ SD卡被占用,不能操作
+ 导出文本时发生错误,请检查SD卡
+ 要查看的便签不存在
+ 不能为空便签设置闹钟提醒
+ 不能将空便签发送到桌面
+ 导出成功
+ 导出失败
+ 已将文本文件(%1$s)输出至SD卡(%2$s)目录
+
+ 同步便签...
+ 同步成功
+ 同步失败
+ 同步已取消
+ 与%1$s同步成功
+ 同步失败,请检查网络和帐号设置
+ 同步失败,发生内部错误
+ 同步已取消
+ 登录%1$s...
+ 正在获取服务器便签列表...
+ 正在同步本地便签...
+
+ 设置
+ 同步账号
+ 与google task同步便签记录
+ 上次同步于 %1$s
+ 添加账号
+ 更换账号
+ 删除账号
+ 取消
+ 立即同步
+ 取消同步
+ 当前帐号 %1$s
+ 如更换同步帐号,过去的帐号同步信息将被清空,再次切换的同时可能会造成数据重复
+ 同步便签
+ 请选择google帐号,便签将与该帐号的google task内容同步。
+ 正在同步中,不能修改同步帐号
+ 同步帐号已设置为%1$s
+ 新建便签背景颜色随机
+ 删除
+ 通话便签
+ 请输入名称
+ 正在搜索便签
+ 搜索便签
+ 便签中的文字
+ 便签
+ 设置
+ 取消
+
+ %1$s 条符合“%2$s”的搜索结果
+
+
+
diff --git a/src/src/app/src/main/res/values-zh-rTW/arrays.xml b/src/src/app/src/main/res/values-zh-rTW/arrays.xml
new file mode 100644
index 0000000..5297209
--- /dev/null
+++ b/src/src/app/src/main/res/values-zh-rTW/arrays.xml
@@ -0,0 +1,23 @@
+
+
+
+
+
+
+ 短信
+ 郵件
+
+
\ No newline at end of file
diff --git a/src/src/app/src/main/res/values/arrays.xml b/src/src/app/src/main/res/values/arrays.xml
new file mode 100644
index 0000000..e00210b
--- /dev/null
+++ b/src/src/app/src/main/res/values/arrays.xml
@@ -0,0 +1,31 @@
+
+
+
+
+
+
+
+ -%s
+ --%s
+ --%s
+ --%s
+
+
+
+ Messaging
+ Email
+
+
\ No newline at end of file
diff --git a/src/src/app/src/main/res/values/colors.xml b/src/src/app/src/main/res/values/colors.xml
new file mode 100644
index 0000000..123ffbf
--- /dev/null
+++ b/src/src/app/src/main/res/values/colors.xml
@@ -0,0 +1,20 @@
+
+
+
+
+
+ #335b5b5b
+
diff --git a/src/src/app/src/main/res/values/dimens.xml b/src/src/app/src/main/res/values/dimens.xml
new file mode 100644
index 0000000..194e84f
--- /dev/null
+++ b/src/src/app/src/main/res/values/dimens.xml
@@ -0,0 +1,24 @@
+
+
+
+
+
+ 33sp
+ 26sp
+ 20sp
+ 17sp
+ 14sp
+
\ No newline at end of file
diff --git a/src/src/app/src/main/res/values/strings.xml b/src/src/app/src/main/res/values/strings.xml
new file mode 100644
index 0000000..b4eaa7c
--- /dev/null
+++ b/src/src/app/src/main/res/values/strings.xml
@@ -0,0 +1,145 @@
+
+
+
+
+
+ set private mode
+ count how many notes are there
+ delete private mode
+ Please input PassWord
+ open the album
+ take photo
+ start draw
+ set gestrue
+ switch to default gestrue
+
+ Notes
+ Notes 2x2
+ Notes 4x4
+ No associated note found, click to create associated note.
+ Privacy mode,can not see note content
+ ...
+ Add note
+ Delete reminder successfully
+ Set reminder
+ Expired
+ yyyyMMdd
+ MMMd kk:mm
+ Got it
+ Take a look
+ Call
+ Send email
+ Browse web
+ Open map
+
+ /MIUI/notes/
+ notes_%s.txt
+
+ (%d)
+ New Folder
+ Export text
+ Sync
+ Cancel syncing
+ Settings
+ Search
+ Delete
+ Move to folder
+ %d selected
+ Nothing selected, the operation is invalid
+ Select all
+ Deselect all
+ Font size
+ Small
+ Medium
+ Large
+ Super
+ Enter check list
+ Leave check list
+ View folder
+ Delete folder
+ Change folder name
+ The folder %1$s exist, please rename
+ Share
+ Send to home
+ Remind me
+ Delete reminder
+ Select folder
+ Parent folder
+ Note added to home
+ Confirm to delete folder and its notes?
+ Delete selected notes
+ Confirm to delete the selected %d notes?
+ Confirm to delete this note?
+ Have moved selected %1$d notes to %2$s folder
+
+ SD card busy, not available now
+ Export failed, please check SD card
+ The note is not exist
+ Sorry, can not set clock on empty note
+ Sorry, can not send and empty note to home
+ Export successful
+ Export fail
+ Export text file (%1$s) to SD (%2$s) directory
+
+ Syncing notes...
+ Sync is successful
+ Sync is failed
+ Sync is canceled
+ Sync is successful with account %1$s
+ Sync failed, please check network and account settings
+ Sync failed, internal error occurs
+ Sync is canceled
+ Logging into %1$s...
+ Getting remote note list...
+ Synchronize local notes with Google Task...
+
+ Settings
+ Sync account
+ Sync notes with google task
+ Last sync time %1$s
+ yyyy-MM-dd hh:mm:ss
+ Add account
+ Change sync account
+ Remove sync account
+ Cancel
+ Sync immediately
+ Cancel syncing
+ Current account %1$s
+ All sync related information will be deleted, which may result in duplicated items sometime
+ Sync notes
+ Please select a google account. Local notes will be synced with google task.
+ Cannot change the account because sync is in progress
+ %1$s has been set as the sync account
+ New note background color random
+
+ Delete
+ Call notes
+ Input name
+
+ Searching Notes
+ Search notes
+ Text in your notes
+ Notes
+ set
+ cancel
+
+ %1$s result for \"%2$s\"
+
+ %1$s results for \"%2$s\"
+
+
+
diff --git a/src/src/app/src/main/res/values/styles.xml b/src/src/app/src/main/res/values/styles.xml
new file mode 100644
index 0000000..c1eddb2
--- /dev/null
+++ b/src/src/app/src/main/res/values/styles.xml
@@ -0,0 +1,68 @@
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
\ No newline at end of file
diff --git a/src/src/app/src/main/res/xml/preferences.xml b/src/src/app/src/main/res/xml/preferences.xml
new file mode 100644
index 0000000..fe58f8f
--- /dev/null
+++ b/src/src/app/src/main/res/xml/preferences.xml
@@ -0,0 +1,30 @@
+
+
+
+
+
+
+
+
+
+
+
+
diff --git a/src/src/app/src/main/res/xml/searchable.xml b/src/src/app/src/main/res/xml/searchable.xml
new file mode 100644
index 0000000..bf74f14
--- /dev/null
+++ b/src/src/app/src/main/res/xml/searchable.xml
@@ -0,0 +1,27 @@
+
+
+
+
+
diff --git a/src/src/app/src/main/res/xml/widget_2x_info.xml b/src/src/app/src/main/res/xml/widget_2x_info.xml
new file mode 100644
index 0000000..ac8b225
--- /dev/null
+++ b/src/src/app/src/main/res/xml/widget_2x_info.xml
@@ -0,0 +1,23 @@
+
+
+
+
+
+
diff --git a/src/src/app/src/main/res/xml/widget_4x_info.xml b/src/src/app/src/main/res/xml/widget_4x_info.xml
new file mode 100644
index 0000000..cf79f9c
--- /dev/null
+++ b/src/src/app/src/main/res/xml/widget_4x_info.xml
@@ -0,0 +1,23 @@
+
+
+
+
+
+
diff --git a/src/src/build.gradle b/src/src/build.gradle
new file mode 100644
index 0000000..9e762ba
--- /dev/null
+++ b/src/src/build.gradle
@@ -0,0 +1,22 @@
+// Top-level build file where you can add configuration options common to all sub-projects/modules.
+
+buildscript {
+ repositories {
+ maven {url "https://plugins.gradle.org/m2/"}
+ maven { url 'http://maven.aliyun.com/nexus/content/groups/public/' }
+ google()
+ //mavenCentral()
+ jcenter()
+
+ }
+ dependencies {
+ classpath 'com.android.tools.build:gradle:4.0.1'
+ }
+}
+allprojects {
+ repositories {
+ google()
+ //mavenCentral()
+ jcenter()
+ }
+}
diff --git a/src/src/build/sonar/.sonar_lock b/src/src/build/sonar/.sonar_lock
new file mode 100644
index 0000000..e69de29
diff --git a/src/src/build/sonar/.sonartmp/scanner-report13442860036873133994.zip b/src/src/build/sonar/.sonartmp/scanner-report13442860036873133994.zip
new file mode 100644
index 0000000..9bd8bf3
Binary files /dev/null and b/src/src/build/sonar/.sonartmp/scanner-report13442860036873133994.zip differ
diff --git a/src/src/build/sonar/report-task.txt b/src/src/build/sonar/report-task.txt
new file mode 100644
index 0000000..a94d108
--- /dev/null
+++ b/src/src/build/sonar/report-task.txt
@@ -0,0 +1,6 @@
+projectKey=M8
+serverUrl=http://localhost:9000
+serverVersion=8.4.2.36762
+dashboardUrl=http://localhost:9000/dashboard?id=M8
+ceTaskId=AXYh_EzudGCc-2BjHzNo
+ceTaskUrl=http://localhost:9000/api/ce/task?id=AXYh_EzudGCc-2BjHzNo
diff --git a/src/src/build/sonar/scanner-report/analysis.log b/src/src/build/sonar/scanner-report/analysis.log
new file mode 100644
index 0000000..17d02aa
--- /dev/null
+++ b/src/src/build/sonar/scanner-report/analysis.log
@@ -0,0 +1,51 @@
+SonarQube plugins:
+ - Python Code Quality and Security 2.13.0.7236 (python)
+ - Chinese Pack 8.4 (l10nzh)
+ - SonarCSS 1.2.0.1325 (cssfamily)
+ - JaCoCo 1.1.0.898 (jacoco)
+ - SonarGo 1.6.0.719 (go)
+ - SonarKotlin 1.5.0.315 (kotlin)
+ - Svn 1.10.0.1917 (scmsvn)
+ - SonarJS 6.2.1.12157 (javascript)
+ - SonarRuby 1.5.0.315 (ruby)
+ - SonarScala 1.5.0.315 (sonarscala)
+ - C# Code Quality and Security 8.9.0.19135 (csharp)
+ - Java Code Quality and Security 6.5.1.22586 (java)
+ - SonarHTML 3.2.0.2082 (web)
+ - Git 1.12.0.2034 (scmgit)
+ - SonarFlex 2.5.1.1831 (flex)
+ - SonarXML 2.0.1.2020 (xml)
+ - PHP Code Quality and Security 3.5.0.5655 (php)
+ - SonarTS 2.1.0.4359 (typescript)
+ - VB.NET Code Quality and Security 8.9.0.19135 (vbnet)
+Global server settings:
+ - sonar.core.id=BF41A1F2-AXUDor05ag0jksdh1Eej
+ - sonar.core.startTime=2020-12-02T13:12:18+0800
+Project server settings:
+Project scanner properties:
+ - sonar.host.url=http://localhost:9000
+ - sonar.login=******
+ - sonar.modules=:app
+ - sonar.projectBaseDir=F:\Git\work_room\p3p7sqtgz\src
+ - sonar.projectKey=M2
+ - sonar.projectName=src
+ - sonar.projectVersion=unspecified
+ - sonar.scanner.app=ScannerGradle
+ - sonar.scanner.appVersion=2.7-SNAPSHOT/6.1.1
+ - sonar.sourceEncoding=GBK
+ - sonar.sources=
+ - sonar.working.directory=F:\Git\work_room\p3p7sqtgz\src\build\sonar
+Scanner properties of module: M2:app
+ - sonar.binaries=F:\Git\work_room\p3p7sqtgz\src\app\build\intermediates\javac\debug\classes
+ - sonar.java.binaries=F:\Git\work_room\p3p7sqtgz\src\app\build\intermediates\javac\debug\classes
+ - sonar.java.libraries=F:\Android\Sdk\platforms\android-28\android.jar,F:\Android\Sdk\platforms\android-28\optional\org.apache.http.legacy.jar,F:\Git\work_room\p3p7sqtgz\src\app\build\intermediates\compile_and_runtime_not_namespaced_r_class_jar\debug\R.jar,C:\Users\Lenovo\.gradle\caches\transforms-2\files-2.1\a595288ec1ef8d315d53e13ae93bdf6d\legacy-support-v4-1.0.0-api.jar,C:\Users\Lenovo\.gradle\caches\transforms-2\files-2.1\a941ef10f83c526c26dc5b1477eb9da8\appcompat-1.0.0-alpha1-api.jar,C:\Users\Lenovo\.gradle\caches\transforms-2\files-2.1\5abc1f602da21f9ce14edc6e9d70ee18\media-1.0.0-api.jar,C:\Users\Lenovo\.gradle\caches\transforms-2\files-2.1\bfa3a71bbf3e2a41f63192774fe572e6\fragment-1.0.0-api.jar,C:\Users\Lenovo\.gradle\caches\transforms-2\files-2.1\f10c20fe18900132f7a65631f1694134\vectordrawable-animated-1.0.0-alpha1-api.jar,C:\Users\Lenovo\.gradle\caches\transforms-2\files-2.1\6dc4310475b78359d794e6b4b4deb68c\legacy-support-core-ui-1.0.0-api.jar,C:\Users\Lenovo\.gradle\caches\transforms-2\files-2.1...
+ - sonar.java.source=1.7
+ - sonar.java.target=1.7
+ - sonar.java.test.binaries=F:\Git\work_room\p3p7sqtgz\src\app\build\intermediates\javac\debugAndroidTest\classes
+ - sonar.java.test.libraries=F:\Android\Sdk\platforms\android-28\android.jar,F:\Android\Sdk\platforms\android-28\optional\org.apache.http.legacy.jar,F:\Git\work_room\p3p7sqtgz\src\app\build\intermediates\compile_and_runtime_not_namespaced_r_class_jar\debug\R.jar,C:\Users\Lenovo\.gradle\caches\transforms-2\files-2.1\a595288ec1ef8d315d53e13ae93bdf6d\legacy-support-v4-1.0.0-api.jar,C:\Users\Lenovo\.gradle\caches\transforms-2\files-2.1\a941ef10f83c526c26dc5b1477eb9da8\appcompat-1.0.0-alpha1-api.jar,C:\Users\Lenovo\.gradle\caches\transforms-2\files-2.1\5abc1f602da21f9ce14edc6e9d70ee18\media-1.0.0-api.jar,C:\Users\Lenovo\.gradle\caches\transforms-2\files-2.1\bfa3a71bbf3e2a41f63192774fe572e6\fragment-1.0.0-api.jar,C:\Users\Lenovo\.gradle\caches\transforms-2\files-2.1\f10c20fe18900132f7a65631f1694134\vectordrawable-animated-1.0.0-alpha1-api.jar,C:\Users\Lenovo\.gradle\caches\transforms-2\files-2.1\6dc4310475b78359d794e6b4b4deb68c\legacy-support-core-ui-1.0.0-api.jar,C:\Users\Lenovo\.gradle\caches\transforms-2\files-2.1...
+ - sonar.libraries=F:\Android\Sdk\platforms\android-28\android.jar,F:\Android\Sdk\platforms\android-28\optional\org.apache.http.legacy.jar,F:\Git\work_room\p3p7sqtgz\src\app\build\intermediates\compile_and_runtime_not_namespaced_r_class_jar\debug\R.jar,C:\Users\Lenovo\.gradle\caches\transforms-2\files-2.1\a595288ec1ef8d315d53e13ae93bdf6d\legacy-support-v4-1.0.0-api.jar,C:\Users\Lenovo\.gradle\caches\transforms-2\files-2.1\a941ef10f83c526c26dc5b1477eb9da8\appcompat-1.0.0-alpha1-api.jar,C:\Users\Lenovo\.gradle\caches\transforms-2\files-2.1\5abc1f602da21f9ce14edc6e9d70ee18\media-1.0.0-api.jar,C:\Users\Lenovo\.gradle\caches\transforms-2\files-2.1\bfa3a71bbf3e2a41f63192774fe572e6\fragment-1.0.0-api.jar,C:\Users\Lenovo\.gradle\caches\transforms-2\files-2.1\f10c20fe18900132f7a65631f1694134\vectordrawable-animated-1.0.0-alpha1-api.jar,C:\Users\Lenovo\.gradle\caches\transforms-2\files-2.1\6dc4310475b78359d794e6b4b4deb68c\legacy-support-core-ui-1.0.0-api.jar,C:\Users\Lenovo\.gradle\caches\transforms-2\files-2.1...
+ - sonar.moduleKey=M2:app
+ - sonar.projectBaseDir=F:\Git\work_room\p3p7sqtgz\src\app
+ - sonar.projectKey=M2:app
+ - sonar.projectName=app
+ - sonar.sources=F:\Git\work_room\p3p7sqtgz\src\app\src\main\AndroidManifest.xml,F:\Git\work_room\p3p7sqtgz\src\app\src\main\java,F:\Git\work_room\p3p7sqtgz\src\app\src\main\res
diff --git a/src/src/build/sonar/scanner-report/issues-10.pb b/src/src/build/sonar/scanner-report/issues-10.pb
new file mode 100644
index 0000000..756efc1
--- /dev/null
+++ b/src/src/build/sonar/scanner-report/issues-10.pb
@@ -0,0 +1,14 @@
+8
+javaS2386Make this member "protected". 2++! 0j
+javaS100NRename this method name to match the regular expression '^[a-z][a-zA-Z0-9]*$'. 2
+ $
+javaS1172&Remove these unused method parameters. 2
+: I:G
+E
+
+: I5Remove this unused method parameter validateVersion".:?
+=
+
+P W-Remove this unused method parameter version".j
+javaS100NRename this method name to match the regular expression '^[a-z][a-zA-Z0-9]*$'. 2
+ (
\ No newline at end of file
diff --git a/src/src/build/sonar/scanner-report/issues-11.pb b/src/src/build/sonar/scanner-report/issues-11.pb
new file mode 100644
index 0000000..10b5bde
Binary files /dev/null and b/src/src/build/sonar/scanner-report/issues-11.pb differ
diff --git a/src/src/build/sonar/scanner-report/issues-12.pb b/src/src/build/sonar/scanner-report/issues-12.pb
new file mode 100644
index 0000000..38fd67e
Binary files /dev/null and b/src/src/build/sonar/scanner-report/issues-12.pb differ
diff --git a/src/src/build/sonar/scanner-report/issues-13.pb b/src/src/build/sonar/scanner-report/issues-13.pb
new file mode 100644
index 0000000..abb4323
--- /dev/null
+++ b/src/src/build/sonar/scanner-report/issues-13.pb
@@ -0,0 +1,10 @@
+
+javaS1319pThe return type of this method should be an interface such as "List" rather than the implementation "ArrayList". 2
+ t
+javaS2293YReplace the type specification in this constructor call with the diamond operator ("<>"). 2**! 'T
+javaS125:=
+;BB7 >-Remove this unused method parameter content".\
+javaS1854ARemove this useless assignment to local variable "pendingIntent". 2IJ 6\
+javaS1854ARemove this useless assignment to local variable "pendingIntent". 2MN 0O
+javaS18744Remove this use of "Notification"; it is deprecated. 2CC( 4K
+javaS18740Remove this use of "defaults"; it is deprecated. 2EE M
+javaS14812Remove this unused "pendingIntent" local variable. 2GG #T
+javaS125"). 2
+@ TW
+javaS1874:Remove this use of "BasicNameValuePair"; it is deprecated. 2
+A SW
+javaS1874:Remove this use of "BasicNameValuePair"; it is deprecated. 2
+ +Y
+javaS1874Remove this use of "setDrawingCacheEnabled"; it is deprecated. 2BB
#T
+javaS18749Remove this use of "buildDrawingCache"; it is deprecated. 2CC
R
+javaS18747Remove this use of "getDrawingCache"; it is deprecated. 2DD )V
+javaS1874;Remove this use of "destroyDrawingCache"; it is deprecated. 2II
Y
+javaS1874>Remove this use of "setDrawingCacheEnabled"; it is deprecated. 2SS
#T
+javaS18749Remove this use of "buildDrawingCache"; it is deprecated. 2TT
R
+javaS18747Remove this use of "getDrawingCache"; it is deprecated. 2UU )V
+javaS1874;Remove this use of "destroyDrawingCache"; it is deprecated. 2^^
\ No newline at end of file
diff --git a/src/src/build/sonar/scanner-report/issues-28.pb b/src/src/build/sonar/scanner-report/issues-28.pb
new file mode 100644
index 0000000..3c94eea
Binary files /dev/null and b/src/src/build/sonar/scanner-report/issues-28.pb differ
diff --git a/src/src/build/sonar/scanner-report/issues-32.pb b/src/src/build/sonar/scanner-report/issues-32.pb
new file mode 100644
index 0000000..8b7c7e0
--- /dev/null
+++ b/src/src/build/sonar/scanner-report/issues-32.pb
@@ -0,0 +1,7 @@
+m
+javaS1128TRemove this unnecessary import: same package classes are always implicitly imported. 2 *h
+javaS100NRename this method name to match the regular expression '^[a-z][a-zA-Z0-9]*$'. 2((
L
+javaS18741Remove this use of "setButton"; it is deprecated. 2== M
+javaS18742Remove this use of "setButton2"; it is deprecated. 2>> P
+javaS18745Remove this use of "FORMAT_24HOUR"; it is deprecated. 2PP* 7P
+javaS18745Remove this use of "FORMAT_12HOUR"; it is deprecated. 2PPD Q
\ No newline at end of file
diff --git a/src/src/build/sonar/scanner-report/issues-35.pb b/src/src/build/sonar/scanner-report/issues-35.pb
new file mode 100644
index 0000000..78b273b
--- /dev/null
+++ b/src/src/build/sonar/scanner-report/issues-35.pb
@@ -0,0 +1,3 @@
+k
+javaS117QRename this local variable to match the regular expression '^[a-z][a-zA-Z0-9]*$'. 2DD "q
+javaS1450VRemove the "gesture" field and declare it as a local variable in the relevant methods. 2 &
\ No newline at end of file
diff --git a/src/src/build/sonar/scanner-report/issues-36.pb b/src/src/build/sonar/scanner-report/issues-36.pb
new file mode 100644
index 0000000..e66fb73
--- /dev/null
+++ b/src/src/build/sonar/scanner-report/issues-36.pb
@@ -0,0 +1,25 @@
+k
+javaS117QRename this local variable to match the regular expression '^[a-z][a-zA-Z0-9]*$'. 2ZZ $k
+javaS117QRename this local variable to match the regular expression '^[a-z][a-zA-Z0-9]*$'. 2ll m
+javaS116SRename this field "ColorBox" to match the regular expression '^[a-z][a-zA-Z0-9]*$'. 2 o
+javaS116URename this field "ColorIndex" to match the regular expression '^[a-z][a-zA-Z0-9]*$'. 2 l
+javaS116RRename this field "SizeBox" to match the regular expression '^[a-z][a-zA-Z0-9]*$'. 2 n
+javaS116TRename this field "SizeIndex" to match the regular expression '^[a-z][a-zA-Z0-9]*$'. 2!! S
+javaS11978Move the array designator from the variable to the type. 2 S
+javaS11978Move the array designator from the variable to the type. 2 R
+javaS18547Remove this useless assignment to local variable "upY". 2QQ" 0R
+javaS18547Remove this useless assignment to local variable "upX". 2PP" 0<
+javaS131"Add a default case to this switch. 2== h
+javaS100NRename this method name to match the regular expression '^[a-z][a-zA-Z0-9]*$'. 2ZZ
+javaS1172+Remove this unused method parameter "View". 2ZZ $::
+8$ZZ $*Remove this unused method parameter View".T
+javaS11179Rename "paint" which hides the field declared at line 26. 2\\
+javaS1172+Remove this unused method parameter "view". 2``! %::
+8$``! %*Remove this unused method parameter view".
+javaS1172+Remove this unused method parameter "view". 2ee ::
+8$ee *Remove this unused method parameter view".
+javaS1172+Remove this unused method parameter "view". 2jj ::
+8$jj *Remove this unused method parameter view".A
+javaS1075&Remove this hard-coded path-delimiter. 2llE HR
+javaS53247Make sure that external files are accessed safely here. 2ll Dp
+javaS4507UMake sure this debug feature is deactivated before delivering the code in production. 2uu
\ No newline at end of file
diff --git a/src/src/build/sonar/scanner-report/issues-37.pb b/src/src/build/sonar/scanner-report/issues-37.pb
new file mode 100644
index 0000000..469f9f7
Binary files /dev/null and b/src/src/build/sonar/scanner-report/issues-37.pb differ
diff --git a/src/src/build/sonar/scanner-report/issues-38.pb b/src/src/build/sonar/scanner-report/issues-38.pb
new file mode 100644
index 0000000..c50e36c
--- /dev/null
+++ b/src/src/build/sonar/scanner-report/issues-38.pb
@@ -0,0 +1,9 @@
+f
+javaS1301KReplace this "switch" statement by "if" statements to increase readability. 2hh M
+javaS11284Remove this unused import 'android.widget.EditText'. 2!! t
+javaS2293YReplace the type specification in this constructor call with the diamond operator ("<>"). 211O `K
+javaS11352Complete the task associated to this TODO comment. 2cc /_
+javaS1126BReplace this if-then-else statement by a single method invocation. 2
+ Q
+javaS28644Iterate over the "entrySet" instead of the "keySet". 2
+
\ No newline at end of file
diff --git a/src/src/build/sonar/scanner-report/issues-39.pb b/src/src/build/sonar/scanner-report/issues-39.pb
new file mode 100644
index 0000000..67f2a7c
Binary files /dev/null and b/src/src/build/sonar/scanner-report/issues-39.pb differ
diff --git a/src/src/build/sonar/scanner-report/issues-4.pb b/src/src/build/sonar/scanner-report/issues-4.pb
new file mode 100644
index 0000000..8bfcbca
--- /dev/null
+++ b/src/src/build/sonar/scanner-report/issues-4.pb
@@ -0,0 +1,6 @@
+U
+javaS1118:Add a private constructor to hide the implicit public one. 2
q
+javaS3252VUse static access with "android.provider.ContactsContract$DataColumns" for "MIMETYPE". 2!! w
+javaS3252\Use static access with "android.provider.ContactsContract$DataColumns" for "RAW_CONTACT_ID". 2"" #t
+javaS2293YReplace the type specification in this constructor call with the diamond operator ("<>"). 2))' 7y
+javaS3252^Use static access with "android.provider.ContactsContract$ContactsColumns" for "DISPLAY_NAME". 244& 2
\ No newline at end of file
diff --git a/src/src/build/sonar/scanner-report/issues-40.pb b/src/src/build/sonar/scanner-report/issues-40.pb
new file mode 100644
index 0000000..ffdd06b
Binary files /dev/null and b/src/src/build/sonar/scanner-report/issues-40.pb differ
diff --git a/src/src/build/sonar/scanner-report/issues-41.pb b/src/src/build/sonar/scanner-report/issues-41.pb
new file mode 100644
index 0000000..d2f3127
Binary files /dev/null and b/src/src/build/sonar/scanner-report/issues-41.pb differ
diff --git a/src/src/build/sonar/scanner-report/issues-43.pb b/src/src/build/sonar/scanner-report/issues-43.pb
new file mode 100644
index 0000000..2306281
Binary files /dev/null and b/src/src/build/sonar/scanner-report/issues-43.pb differ
diff --git a/src/src/build/sonar/scanner-report/issues-45.pb b/src/src/build/sonar/scanner-report/issues-45.pb
new file mode 100644
index 0000000..0f9d03d
--- /dev/null
+++ b/src/src/build/sonar/scanner-report/issues-45.pb
@@ -0,0 +1,2 @@
+g
+javaS101MRename this class name to match the regular expression '^[A-Z][a-zA-Z0-9]*$'. 2
"
\ No newline at end of file
diff --git a/src/src/build/sonar/scanner-report/issues-46.pb b/src/src/build/sonar/scanner-report/issues-46.pb
new file mode 100644
index 0000000..0f9d03d
--- /dev/null
+++ b/src/src/build/sonar/scanner-report/issues-46.pb
@@ -0,0 +1,2 @@
+g
+javaS101MRename this class name to match the regular expression '^[A-Z][a-zA-Z0-9]*$'. 2
"
\ No newline at end of file
diff --git a/src/src/build/sonar/scanner-report/issues-6.pb b/src/src/build/sonar/scanner-report/issues-6.pb
new file mode 100644
index 0000000..274b63d
Binary files /dev/null and b/src/src/build/sonar/scanner-report/issues-6.pb differ
diff --git a/src/src/build/sonar/scanner-report/issues-7.pb b/src/src/build/sonar/scanner-report/issues-7.pb
new file mode 100644
index 0000000..8cc7ca4
Binary files /dev/null and b/src/src/build/sonar/scanner-report/issues-7.pb differ
diff --git a/src/src/build/sonar/scanner-report/issues-8.pb b/src/src/build/sonar/scanner-report/issues-8.pb
new file mode 100644
index 0000000..006e4f8
--- /dev/null
+++ b/src/src/build/sonar/scanner-report/issues-8.pb
@@ -0,0 +1,2 @@
+`
+javaS1124EReorder the modifiers to comply with the Java Language Specification. 2
\ No newline at end of file
diff --git a/src/src/build/sonar/scanner-report/measures-10.pb b/src/src/build/sonar/scanner-report/measures-10.pb
new file mode 100644
index 0000000..3ec2fc6
Binary files /dev/null and b/src/src/build/sonar/scanner-report/measures-10.pb differ
diff --git a/src/src/build/sonar/scanner-report/measures-11.pb b/src/src/build/sonar/scanner-report/measures-11.pb
new file mode 100644
index 0000000..1b1c1e4
--- /dev/null
+++ b/src/src/build/sonar/scanner-report/measures-11.pb
@@ -0,0 +1,15 @@
+
+classes
+ functions
+
+complexity`
+
comment_lines
+
+statements
+ncloc
+cognitive_complexity
+executable_lines_data2
+42=1;44=1;46=1;47=1;48=1;49=1;50=1;51=1;52=1;126=1;127=1;128=1;129=1;130=1;131=1;132=1;133=1;134=1;135=1;136=1;137=1;138=1;139=1;140=1;141=1;142=1;143=1;144=1;147=1;148=1;149=1;150=1;151=1;152=1;153=1;154=1;155=1;158=1;159=1;160=1;161=1;162=1;163=1;164=1;165=1;167=1;170=1;172=1;173=1;174=1;175=1;176=1;177=1;178=1;180=1;183=1;184=1;185=1;186=1;189=1;190=1;191=1;192=1;193=1;194=1;195=1;196=1;197=1;198=1;199=1;200=1;201=1;204=1;205=1;207=1;208=1;209=1;210=1;211=1;212=1;213=1;216=1;217=1;218=1;219=1;221=1;224=1;225=1;226=1;227=1;231=1;232=1;233=1;234=1;236=1;237=1;238=1;239=1;241=1;243=1;244=1;245=1;246=1;248=1;249=1;250=1;251=1;252=1;253=1;255=1;257=1;258=1;259=1;260=1;262=1;264=1;265=1;266=1;267=1;269=1;271=1;272=1;273=1;274=1;276=1;278=1;279=1;280=1;281=1;283=1;285=1;286=1;287=1;288=1;290=1;292=1;293=1;294=1;295=1;297=1;299=1;300=1;301=1;302=1;304=1;306=1;307=1;308=1;309=1;311=1;313=1;314=1;315=1;316=1;318=1;320=1;321=1;322=1;323=1;325=1;327=1;328=1;329=1;330=1;332=1;334=1;335=1;336=1;337=1;338=1;339=1;340=1;341=1;343=1;346=1;347=1;348=1;351=1;352=1;354=1;355=1;357=1;358=1;359=1;364=1;366=1;367=1;368=1;371=1;372=1;373=1;374=1;375=1;376=1;377=1;378=1;379=1;380=1;381=1;382=1;383=1;384=1;385=1;387=1;388=1;389=1;390=1;391=1;393=1;394=1;395=1;396=1;397=1;398=1;399=1;402=1;403=1;404=1;406=1;407=1;411=1;412=1;413=1;416=1;417=1;420=1;421=1;424=1;425=1;428=1;432=1;436=1;440=1;444=1;445=1;446=1;449=1;451=1;452=1;453=1;454=1;455=1;456=1;457=1;460=1;461=1;462=1;463=1;466=1;467=1;468=1;470=1;471=1;472=1;473=1;474=1;475=1;476=1;479=1;480=1;481=1;482=1;485=1;486=1;490=1;491=1;492=1;493=1;498=1;499=1;500=1;502=1;503=1;504=1
+
+ncloc_data2
+17=1;19=1;20=1;21=1;22=1;23=1;24=1;25=1;27=1;28=1;29=1;30=1;31=1;32=1;34=1;35=1;36=1;38=1;41=1;42=1;44=1;46=1;47=1;48=1;49=1;50=1;51=1;52=1;53=1;55=1;57=1;59=1;61=1;63=1;65=1;67=1;69=1;71=1;73=1;75=1;77=1;79=1;81=1;83=1;85=1;87=1;89=1;91=1;93=1;95=1;97=1;99=1;101=1;103=1;105=1;107=1;109=1;111=1;113=1;115=1;117=1;119=1;121=1;123=1;125=1;126=1;127=1;128=1;129=1;130=1;131=1;132=1;133=1;134=1;135=1;136=1;137=1;138=1;139=1;140=1;141=1;142=1;143=1;144=1;146=1;147=1;148=1;149=1;150=1;151=1;152=1;153=1;154=1;155=1;157=1;158=1;159=1;160=1;161=1;162=1;163=1;164=1;165=1;167=1;169=1;170=1;171=1;172=1;173=1;174=1;175=1;176=1;177=1;178=1;179=1;180=1;181=1;182=1;183=1;184=1;185=1;186=1;188=1;189=1;190=1;191=1;192=1;193=1;194=1;195=1;196=1;197=1;198=1;199=1;200=1;201=1;203=1;204=1;205=1;206=1;207=1;208=1;209=1;210=1;211=1;212=1;213=1;214=1;215=1;216=1;217=1;218=1;219=1;220=1;221=1;222=1;223=1;224=1;225=1;226=1;227=1;229=1;230=1;231=1;232=1;233=1;234=1;236=1;237=1;238=1;239=1;240=1;241=1;243=1;244=1;245=1;246=1;247=1;248=1;249=1;250=1;251=1;252=1;253=1;254=1;255=1;257=1;258=1;259=1;260=1;261=1;262=1;264=1;265=1;266=1;267=1;268=1;269=1;271=1;272=1;273=1;274=1;275=1;276=1;278=1;279=1;280=1;281=1;282=1;283=1;285=1;286=1;287=1;288=1;289=1;290=1;292=1;293=1;294=1;295=1;296=1;297=1;299=1;300=1;301=1;302=1;303=1;304=1;306=1;307=1;308=1;309=1;310=1;311=1;313=1;314=1;315=1;316=1;317=1;318=1;320=1;321=1;322=1;323=1;324=1;325=1;327=1;328=1;329=1;330=1;331=1;332=1;334=1;335=1;336=1;337=1;338=1;339=1;340=1;341=1;342=1;343=1;344=1;346=1;347=1;348=1;349=1;351=1;352=1;353=1;354=1;355=1;357=1;358=1;359=1;360=1;362=1;363=1;364=1;366=1;367=1;368=1;369=1;371=1;372=1;373=1;374=1;375=1;376=1;377=1;378=1;379=1;380=1;381=1;382=1;383=1;384=1;385=1;387=1;388=1;389=1;390=1;391=1;392=1;393=1;394=1;395=1;396=1;397=1;398=1;399=1;400=1;402=1;403=1;404=1;406=1;407=1;408=1;410=1;411=1;412=1;413=1;415=1;416=1;417=1;419=1;420=1;421=1;423=1;424=1;425=1;427=1;428=1;429=1;431=1;432=1;433=1;435=1;436=1;437=1;439=1;440=1;441=1;443=1;444=1;445=1;446=1;447=1;449=1;450=1;451=1;452=1;453=1;454=1;455=1;456=1;457=1;458=1;460=1;461=1;462=1;463=1;464=1;465=1;466=1;467=1;468=1;469=1;470=1;471=1;472=1;473=1;474=1;475=1;476=1;477=1;478=1;479=1;480=1;481=1;482=1;483=1;484=1;485=1;486=1;487=1;488=1;490=1;491=1;492=1;493=1;494=1;495=1;498=1;499=1;500=1;502=1;503=1;504=1;505=1;506=1
\ No newline at end of file
diff --git a/src/src/build/sonar/scanner-report/measures-12.pb b/src/src/build/sonar/scanner-report/measures-12.pb
new file mode 100644
index 0000000..a5520a0
--- /dev/null
+++ b/src/src/build/sonar/scanner-report/measures-12.pb
@@ -0,0 +1,15 @@
+
+classes
+ functions
+
+complexity5
+
comment_lines
+
+statements
+ncloc
+cognitive_complexityB
+executable_lines_data2
+257=1;258=1;259=1;260=1;261=1;263=1;267=1;268=1;269=1;272=1;273=1;274=1;277=1;278=1;279=1;283=1;284=1;285=1;288=1;290=1;36=1;292=1;295=1;299=1;300=1;301=1;303=1;49=1;305=1;50=1;51=1;307=1;52=1;53=1;54=1;310=1;55=1;311=1;313=1;58=1;315=1;62=1;63=1;319=1;320=1;66=1;324=1;69=1;325=1;72=1;328=1;73=1;329=1;74=1;75=1;76=1;332=1;77=1;333=1;78=1;80=1;336=1;337=1;83=1;340=1;86=1;87=1;344=1;90=1;348=1;93=1;94=1;352=1;97=1;98=1;100=1;101=1;103=1;107=1;111=1;112=1;115=1;118=1;121=1;122=1;123=1;124=1;126=1;127=1;129=1;130=1;132=1;133=1;135=1;139=1;142=1;143=1;147=1;148=1;152=1;153=1;157=1;158=1;162=1;163=1;167=1;168=1;170=1;171=1;173=1;174=1;176=1;179=1;180=1;181=1;185=1;186=1;187=1;189=1;190=1;194=1;195=1;196=1;197=1;200=1;203=1;205=1;206=1;208=1;209=1;212=1;214=1;216=1;217=1;218=1;221=1;222=1;223=1;224=1;225=1;226=1;227=1;228=1;229=1;230=1;233=1;234=1;236=1;237=1;238=1;239=1;242=1;244=1;245=1;247=1;248=1;250=1;251=1;255=1
+
+ncloc_data2
+17=1;19=1;20=1;21=1;23=1;24=1;25=1;26=1;27=1;28=1;30=1;31=1;32=1;35=1;36=1;38=1;40=1;42=1;44=1;46=1;48=1;49=1;50=1;51=1;52=1;53=1;54=1;55=1;57=1;58=1;60=1;62=1;63=1;66=1;69=1;72=1;73=1;74=1;75=1;76=1;77=1;78=1;79=1;80=1;83=1;86=1;87=1;90=1;93=1;94=1;95=1;97=1;98=1;100=1;101=1;103=1;104=1;106=1;107=1;109=1;111=1;112=1;115=1;118=1;121=1;122=1;123=1;124=1;125=1;126=1;127=1;129=1;130=1;132=1;133=1;135=1;136=1;138=1;139=1;140=1;142=1;143=1;144=1;147=1;148=1;149=1;152=1;153=1;154=1;157=1;158=1;159=1;162=1;163=1;164=1;167=1;168=1;169=1;170=1;171=1;173=1;174=1;175=1;176=1;178=1;179=1;180=1;181=1;182=1;184=1;185=1;186=1;187=1;189=1;190=1;191=1;192=1;194=1;195=1;196=1;197=1;198=1;199=1;200=1;201=1;202=1;203=1;204=1;205=1;206=1;208=1;209=1;211=1;212=1;213=1;214=1;216=1;217=1;218=1;219=1;221=1;222=1;223=1;224=1;225=1;226=1;227=1;228=1;229=1;230=1;231=1;233=1;234=1;236=1;237=1;238=1;239=1;240=1;241=1;242=1;244=1;245=1;246=1;247=1;248=1;250=1;251=1;252=1;254=1;255=1;256=1;257=1;258=1;259=1;260=1;261=1;262=1;263=1;265=1;266=1;267=1;268=1;269=1;270=1;272=1;273=1;274=1;275=1;277=1;278=1;279=1;280=1;283=1;284=1;285=1;286=1;288=1;290=1;292=1;293=1;295=1;296=1;297=1;299=1;300=1;301=1;302=1;303=1;305=1;306=1;307=1;308=1;309=1;310=1;311=1;313=1;315=1;316=1;318=1;319=1;320=1;321=1;323=1;324=1;325=1;327=1;328=1;329=1;331=1;332=1;333=1;335=1;336=1;337=1;339=1;340=1;341=1;343=1;344=1;345=1;347=1;348=1;349=1;351=1;352=1;353=1;355=1;356=1
\ No newline at end of file
diff --git a/src/src/build/sonar/scanner-report/measures-13.pb b/src/src/build/sonar/scanner-report/measures-13.pb
new file mode 100644
index 0000000..5f5ba3f
--- /dev/null
+++ b/src/src/build/sonar/scanner-report/measures-13.pb
@@ -0,0 +1,15 @@
+
+classes
+ functions
+
+complexity?
+
comment_lines
+
+statements
+ncloc
+cognitive_complexityR
+executable_lines_data2
+256=1;257=1;258=1;259=1;261=1;262=1;263=1;266=1;270=1;271=1;272=1;273=1;275=1;277=1;278=1;281=1;282=1;283=1;287=1;34=1;292=1;293=1;294=1;41=1;297=1;42=1;298=1;43=1;299=1;44=1;300=1;47=1;303=1;304=1;305=1;51=1;52=1;309=1;310=1;55=1;311=1;312=1;58=1;314=1;315=1;61=1;62=1;63=1;319=1;64=1;65=1;66=1;323=1;68=1;324=1;69=1;325=1;71=1;327=1;72=1;74=1;331=1;332=1;333=1;78=1;334=1;335=1;82=1;83=1;339=1;86=1;343=1;344=1;89=1;347=1;92=1;93=1;94=1;95=1;97=1;98=1;100=1;101=1;103=1;107=1;110=1;111=1;115=1;116=1;120=1;121=1;124=1;125=1;127=1;128=1;130=1;133=1;134=1;136=1;138=1;140=1;141=1;142=1;143=1;144=1;145=1;146=1;147=1;148=1;150=1;152=1;154=1;155=1;157=1;160=1;162=1;166=1;167=1;169=1;170=1;171=1;172=1;173=1;174=1;175=1;176=1;178=1;180=1;182=1;183=1;184=1;186=1;187=1;192=1;194=1;196=1;199=1;203=1;204=1;205=1;208=1;210=1;213=1;217=1;218=1;220=1;222=1;226=1;230=1;231=1;232=1;233=1;235=1;236=1;237=1;240=1;244=1;245=1;246=1;249=1;250=1;251=1;254=1;255=1
+
+ncloc_data2
+17=1;19=1;20=1;22=1;23=1;24=1;25=1;27=1;28=1;30=1;33=1;34=1;36=1;38=1;40=1;41=1;42=1;43=1;44=1;46=1;47=1;49=1;51=1;52=1;55=1;58=1;61=1;62=1;63=1;64=1;65=1;66=1;68=1;69=1;71=1;72=1;74=1;75=1;77=1;78=1;80=1;82=1;83=1;86=1;89=1;92=1;93=1;94=1;95=1;97=1;98=1;100=1;101=1;103=1;104=1;106=1;107=1;108=1;110=1;111=1;112=1;115=1;116=1;117=1;120=1;121=1;122=1;124=1;125=1;127=1;128=1;129=1;130=1;132=1;133=1;134=1;135=1;136=1;137=1;138=1;140=1;141=1;142=1;143=1;144=1;145=1;146=1;147=1;148=1;149=1;150=1;151=1;152=1;153=1;154=1;155=1;157=1;158=1;159=1;160=1;161=1;162=1;164=1;165=1;166=1;167=1;169=1;170=1;171=1;172=1;173=1;174=1;175=1;176=1;177=1;178=1;180=1;182=1;183=1;184=1;186=1;187=1;188=1;190=1;191=1;192=1;194=1;196=1;197=1;199=1;200=1;201=1;203=1;204=1;205=1;206=1;208=1;210=1;211=1;213=1;214=1;216=1;217=1;218=1;220=1;222=1;223=1;225=1;226=1;227=1;229=1;230=1;231=1;232=1;233=1;235=1;236=1;237=1;238=1;239=1;240=1;241=1;243=1;244=1;245=1;246=1;247=1;249=1;250=1;251=1;254=1;255=1;256=1;257=1;258=1;259=1;261=1;262=1;263=1;264=1;266=1;267=1;269=1;270=1;271=1;272=1;273=1;275=1;277=1;278=1;281=1;282=1;283=1;284=1;285=1;286=1;287=1;288=1;290=1;292=1;293=1;294=1;295=1;297=1;298=1;299=1;300=1;301=1;303=1;304=1;305=1;306=1;308=1;309=1;310=1;311=1;312=1;313=1;314=1;315=1;316=1;318=1;319=1;320=1;322=1;323=1;324=1;325=1;326=1;327=1;328=1;330=1;331=1;332=1;333=1;334=1;335=1;336=1;338=1;339=1;340=1;342=1;343=1;344=1;346=1;347=1;348=1;349=1;350=1
\ No newline at end of file
diff --git a/src/src/build/sonar/scanner-report/measures-14.pb b/src/src/build/sonar/scanner-report/measures-14.pb
new file mode 100644
index 0000000..494cb32
Binary files /dev/null and b/src/src/build/sonar/scanner-report/measures-14.pb differ
diff --git a/src/src/build/sonar/scanner-report/measures-15.pb b/src/src/build/sonar/scanner-report/measures-15.pb
new file mode 100644
index 0000000..494cb32
Binary files /dev/null and b/src/src/build/sonar/scanner-report/measures-15.pb differ
diff --git a/src/src/build/sonar/scanner-report/measures-16.pb b/src/src/build/sonar/scanner-report/measures-16.pb
new file mode 100644
index 0000000..4bc45c0
--- /dev/null
+++ b/src/src/build/sonar/scanner-report/measures-16.pb
@@ -0,0 +1,15 @@
+
+classes
+ functions
+
+complexity
+
comment_lines
+
+statements
+nclocU
+cognitive_complexity
+executable_lines_data2
+64=1;128=1;67=1;131=1;68=1;132=1;69=1;70=1;71=1;135=1;72=1;73=1;74=1;77=1;78=1;95=1;96=1;34=1;100=1;101=1;102=1;107=1;108=1;109=1;111=1;49=1;50=1;51=1;115=1;52=1;116=1;53=1;117=1;54=1;118=1;119=1;120=1;57=1;121=1;58=1;122=1;123=1;124=1;61=1;125=1;62=1;127=1
+
+ncloc_data2
+128=1;130=1;131=1;132=1;133=1;134=1;135=1;136=1;137=1;18=1;20=1;21=1;22=1;23=1;24=1;25=1;27=1;28=1;29=1;32=1;34=1;36=1;37=1;38=1;40=1;42=1;44=1;46=1;48=1;49=1;50=1;51=1;52=1;53=1;54=1;56=1;57=1;58=1;60=1;61=1;62=1;63=1;64=1;66=1;67=1;68=1;69=1;70=1;71=1;72=1;73=1;74=1;76=1;77=1;78=1;79=1;95=1;96=1;98=1;99=1;100=1;101=1;102=1;103=1;105=1;106=1;107=1;108=1;109=1;110=1;111=1;113=1;114=1;115=1;116=1;117=1;118=1;119=1;120=1;121=1;122=1;123=1;124=1;125=1;126=1;127=1
\ No newline at end of file
diff --git a/src/src/build/sonar/scanner-report/measures-17.pb b/src/src/build/sonar/scanner-report/measures-17.pb
new file mode 100644
index 0000000..866b819
--- /dev/null
+++ b/src/src/build/sonar/scanner-report/measures-17.pb
@@ -0,0 +1,15 @@
+
+classes
+ functions
+
+complexityA
+
comment_lines/
+
+statements
+ncloc
+cognitive_complexityF
+executable_lines_data2
+512=1;513=1;516=1;517=1;518=1;522=1;523=1;524=1;527=1;528=1;529=1;530=1;531=1;532=1;533=1;534=1;536=1;537=1;538=1;539=1;541=1;542=1;543=1;545=1;546=1;547=1;549=1;550=1;554=1;556=1;557=1;558=1;561=1;562=1;563=1;564=1;565=1;566=1;567=1;570=1;572=1;573=1;574=1;575=1;577=1;578=1;67=1;582=1;586=1;75=1;587=1;96=1;97=1;98=1;99=1;100=1;101=1;102=1;103=1;104=1;105=1;108=1;109=1;111=1;117=1;118=1;119=1;120=1;121=1;122=1;126=1;127=1;128=1;129=1;132=1;133=1;134=1;137=1;138=1;139=1;140=1;141=1;145=1;146=1;147=1;148=1;149=1;150=1;151=1;152=1;154=1;155=1;160=1;161=1;162=1;163=1;164=1;168=1;169=1;173=1;174=1;175=1;177=1;178=1;179=1;182=1;183=1;184=1;185=1;186=1;189=1;190=1;191=1;193=1;194=1;198=1;199=1;201=1;202=1;203=1;204=1;205=1;207=1;208=1;209=1;210=1;212=1;216=1;219=1;220=1;221=1;222=1;225=1;226=1;227=1;230=1;234=1;235=1;236=1;237=1;238=1;239=1;240=1;241=1;242=1;246=1;247=1;248=1;249=1;252=1;253=1;254=1;255=1;256=1;258=1;259=1;260=1;264=1;265=1;266=1;267=1;268=1;269=1;270=1;271=1;273=1;274=1;275=1;276=1;278=1;279=1;281=1;282=1;283=1;285=1;289=1;293=1;294=1;295=1;296=1;301=1;302=1;303=1;304=1;307=1;308=1;309=1;310=1;311=1;312=1;315=1;316=1;317=1;318=1;319=1;320=1;322=1;323=1;325=1;326=1;330=1;331=1;332=1;335=1;337=1;338=1;339=1;340=1;343=1;344=1;345=1;347=1;348=1;350=1;351=1;352=1;354=1;355=1;356=1;358=1;359=1;360=1;362=1;363=1;367=1;369=1;370=1;373=1;374=1;377=1;380=1;381=1;382=1;383=1;385=1;386=1;388=1;389=1;390=1;393=1;395=1;396=1;399=1;400=1;403=1;406=1;407=1;408=1;409=1;411=1;412=1;414=1;415=1;416=1;419=1;421=1;424=1;427=1;429=1;430=1;431=1;432=1;434=1;435=1;437=1;440=1;443=1;444=1;447=1;448=1;449=1;451=1;455=1;457=1;458=1;459=1;462=1;463=1;464=1;465=1;466=1;469=1;471=1;472=1;473=1;475=1;477=1;478=1;481=1;483=1;485=1;486=1;488=1;489=1;490=1;493=1;495=1;496=1;499=1;500=1;501=1;504=1;506=1;507=1;508=1;509=1;511=1
+
+ncloc_data2
+17=1;19=1;20=1;21=1;22=1;23=1;24=1;25=1;26=1;27=1;29=1;30=1;31=1;32=1;33=1;34=1;35=1;37=1;38=1;39=1;40=1;41=1;42=1;43=1;44=1;45=1;46=1;47=1;48=1;49=1;50=1;51=1;52=1;53=1;55=1;56=1;57=1;58=1;59=1;60=1;61=1;62=1;63=1;66=1;67=1;69=1;71=1;73=1;75=1;77=1;79=1;81=1;83=1;85=1;87=1;89=1;91=1;93=1;95=1;96=1;97=1;98=1;99=1;100=1;101=1;102=1;103=1;104=1;105=1;107=1;108=1;109=1;110=1;111=1;112=1;114=1;117=1;118=1;119=1;120=1;121=1;122=1;123=1;126=1;127=1;128=1;129=1;130=1;132=1;133=1;134=1;135=1;137=1;138=1;139=1;140=1;141=1;142=1;145=1;146=1;147=1;148=1;149=1;150=1;151=1;152=1;154=1;155=1;156=1;157=1;160=1;161=1;162=1;163=1;164=1;165=1;166=1;168=1;169=1;170=1;172=1;173=1;174=1;175=1;177=1;178=1;179=1;180=1;182=1;183=1;184=1;185=1;186=1;187=1;188=1;189=1;190=1;191=1;192=1;193=1;194=1;195=1;198=1;199=1;200=1;201=1;202=1;203=1;204=1;205=1;206=1;207=1;208=1;209=1;210=1;212=1;213=1;215=1;216=1;219=1;220=1;221=1;222=1;223=1;225=1;226=1;227=1;228=1;229=1;230=1;231=1;233=1;234=1;235=1;236=1;237=1;238=1;239=1;240=1;241=1;242=1;245=1;246=1;247=1;248=1;249=1;252=1;253=1;254=1;255=1;256=1;257=1;258=1;259=1;260=1;261=1;264=1;265=1;266=1;267=1;268=1;269=1;270=1;271=1;272=1;273=1;274=1;275=1;276=1;278=1;279=1;281=1;282=1;283=1;285=1;286=1;288=1;289=1;290=1;292=1;293=1;294=1;295=1;296=1;297=1;299=1;300=1;301=1;302=1;303=1;304=1;305=1;307=1;308=1;309=1;310=1;311=1;312=1;313=1;315=1;316=1;317=1;318=1;319=1;320=1;321=1;322=1;323=1;324=1;325=1;326=1;327=1;329=1;330=1;331=1;332=1;333=1;335=1;336=1;337=1;338=1;339=1;340=1;343=1;344=1;345=1;347=1;348=1;350=1;351=1;352=1;354=1;355=1;356=1;358=1;359=1;360=1;362=1;363=1;364=1;366=1;367=1;368=1;369=1;370=1;373=1;374=1;377=1;380=1;381=1;382=1;383=1;385=1;386=1;388=1;389=1;390=1;392=1;393=1;394=1;395=1;396=1;399=1;400=1;403=1;406=1;407=1;408=1;409=1;411=1;412=1;414=1;415=1;416=1;418=1;419=1;420=1;421=1;424=1;427=1;429=1;430=1;431=1;432=1;434=1;435=1;436=1;437=1;439=1;440=1;443=1;444=1;445=1;447=1;448=1;449=1;450=1;451=1;453=1;454=1;455=1;456=1;457=1;458=1;459=1;462=1;463=1;464=1;465=1;466=1;469=1;470=1;471=1;472=1;473=1;475=1;476=1;477=1;478=1;481=1;483=1;485=1;486=1;488=1;489=1;490=1;492=1;493=1;494=1;495=1;496=1;499=1;500=1;501=1;504=1;506=1;507=1;508=1;509=1;511=1;512=1;513=1;515=1;516=1;517=1;518=1;519=1;521=1;522=1;523=1;524=1;527=1;528=1;529=1;530=1;531=1;532=1;533=1;534=1;535=1;536=1;537=1;538=1;539=1;541=1;542=1;543=1;545=1;546=1;547=1;549=1;550=1;551=1;553=1;554=1;555=1;556=1;557=1;558=1;561=1;562=1;563=1;564=1;565=1;566=1;567=1;570=1;572=1;573=1;574=1;575=1;577=1;578=1;579=1;581=1;582=1;583=1;585=1;586=1;587=1;588=1;589=1
\ No newline at end of file
diff --git a/src/src/build/sonar/scanner-report/measures-18.pb b/src/src/build/sonar/scanner-report/measures-18.pb
new file mode 100644
index 0000000..f501687
--- /dev/null
+++ b/src/src/build/sonar/scanner-report/measures-18.pb
@@ -0,0 +1,15 @@
+
+classes
+ functions
+
+complexityq
+
comment_lines4
+
+statements
+ncloc
+cognitive_complexity
+executable_lines_data2
+52=1;64=1;91=1;92=1;93=1;94=1;95=1;96=1;97=1;98=1;99=1;100=1;103=1;104=1;106=1;111=1;112=1;115=1;116=1;117=1;119=1;120=1;121=1;122=1;123=1;124=1;125=1;126=1;127=1;128=1;131=1;132=1;135=1;136=1;137=1;142=1;143=1;146=1;147=1;148=1;149=1;150=1;151=1;152=1;153=1;154=1;155=1;157=1;159=1;160=1;161=1;162=1;163=1;164=1;165=1;166=1;168=1;172=1;174=1;176=1;179=1;180=1;181=1;182=1;183=1;185=1;186=1;187=1;188=1;191=1;192=1;193=1;194=1;195=1;196=1;197=1;198=1;199=1;202=1;204=1;207=1;208=1;209=1;210=1;211=1;215=1;216=1;217=1;218=1;220=1;221=1;222=1;223=1;224=1;225=1;226=1;229=1;230=1;231=1;232=1;233=1;234=1;235=1;236=1;237=1;238=1;240=1;242=1;243=1;244=1;246=1;247=1;248=1;251=1;252=1;253=1;254=1;256=1;258=1;264=1;265=1;266=1;267=1;268=1;269=1;270=1;271=1;272=1;273=1;274=1;277=1;278=1;280=1;283=1;284=1;285=1;287=1;290=1;294=1;295=1;296=1;297=1;298=1;299=1;300=1;301=1;302=1;303=1;304=1;305=1;306=1;308=1;310=1;313=1;316=1;317=1;319=1;323=1;324=1;325=1;327=1;330=1;331=1;332=1;333=1;335=1;336=1;337=1;338=1;340=1;345=1;346=1;347=1;352=1;353=1;354=1;357=1;360=1;361=1;362=1;363=1;365=1;371=1;372=1;373=1;374=1;375=1;376=1;377=1;378=1;379=1;380=1;382=1;383=1;384=1;386=1;389=1;392=1;393=1;394=1;396=1;400=1;401=1;402=1;403=1;404=1;405=1;406=1;407=1;408=1;409=1;410=1;411=1;414=1;415=1;416=1;417=1;419=1;423=1;426=1;427=1;428=1;430=1;434=1;435=1;436=1;437=1;438=1;439=1;440=1;441=1;442=1;443=1;444=1;445=1;446=1;448=1;450=1;453=1;456=1;457=1;459=1;462=1;463=1;464=1;466=1;469=1;470=1;471=1;472=1;473=1;474=1;475=1;477=1;478=1;479=1;480=1;482=1;484=1;485=1;486=1;489=1;493=1;494=1;495=1;496=1;498=1;499=1;501=1;502=1;503=1;504=1;506=1;508=1;509=1;510=1;511=1;513=1;515=1;516=1;518=1;519=1;521=1;524=1;526=1;528=1;530=1;532=1;535=1;539=1;540=1;541=1;542=1;543=1;544=1;545=1;546=1;548=1;549=1;550=1;553=1;554=1;556=1;557=1;558=1;559=1;560=1;562=1;567=1;568=1;569=1;570=1;571=1;572=1;573=1;576=1;579=1;582=1;583=1;585=1;586=1;588=1;589=1;590=1;591=1;593=1;597=1;598=1;601=1;602=1;605=1;606=1;609=1;613=1;615=1;616=1;618=1;619=1;620=1;621=1;622=1;624=1;625=1;628=1;629=1;632=1;636=1;637=1;640=1;641=1;642=1;644=1;645=1;646=1;647=1;649=1;651=1;652=1;655=1;657=1;660=1;661=1;662=1;663=1;664=1;666=1;668=1;669=1;670=1;671=1;672=1;674=1;675=1;676=1;677=1;681=1;684=1;685=1;686=1;687=1;688=1;690=1;694=1;695=1;696=1;697=1;700=1;701=1;702=1;705=1;709=1;712=1;713=1;716=1;719=1;720=1;721=1;723=1;724=1;725=1;726=1;728=1;730=1;731=1;732=1;733=1;738=1;739=1;740=1;743=1;744=1;745=1;746=1;747=1;749=1;750=1;751=1;752=1;753=1;756=1;759=1;764=1;765=1;766=1;767=1;769=1;771=1;772=1;773=1;774=1;775=1;776=1;777=1;778=1;779=1;780=1;781=1;782=1;783=1;784=1;786=1;787=1;788=1;790=1;792=1;795=1;796=1;797=1;799=1;800=1;803=1;807=1;808=1
+
+ncloc_data2
+17=1;19=1;20=1;21=1;22=1;23=1;24=1;25=1;27=1;28=1;29=1;30=1;31=1;32=1;33=1;34=1;35=1;36=1;37=1;38=1;39=1;41=1;42=1;43=1;45=1;46=1;47=1;48=1;51=1;52=1;54=1;56=1;58=1;60=1;62=1;64=1;66=1;68=1;70=1;72=1;74=1;76=1;78=1;80=1;82=1;84=1;86=1;88=1;90=1;91=1;92=1;93=1;94=1;95=1;96=1;97=1;98=1;99=1;100=1;102=1;103=1;104=1;105=1;106=1;107=1;109=1;111=1;112=1;114=1;115=1;116=1;117=1;118=1;119=1;120=1;121=1;122=1;123=1;124=1;125=1;126=1;127=1;128=1;130=1;131=1;132=1;135=1;136=1;137=1;138=1;139=1;142=1;143=1;146=1;147=1;148=1;149=1;150=1;151=1;152=1;153=1;154=1;155=1;157=1;158=1;159=1;160=1;161=1;162=1;163=1;164=1;165=1;166=1;168=1;169=1;171=1;172=1;173=1;174=1;175=1;176=1;179=1;180=1;181=1;182=1;183=1;185=1;186=1;187=1;188=1;191=1;192=1;193=1;194=1;195=1;196=1;197=1;198=1;199=1;200=1;201=1;202=1;203=1;204=1;207=1;208=1;209=1;210=1;211=1;212=1;215=1;216=1;217=1;218=1;220=1;221=1;222=1;223=1;224=1;225=1;226=1;229=1;230=1;231=1;232=1;233=1;234=1;235=1;236=1;237=1;238=1;239=1;240=1;241=1;242=1;243=1;244=1;246=1;247=1;248=1;250=1;251=1;252=1;253=1;254=1;256=1;258=1;259=1;260=1;263=1;264=1;265=1;266=1;267=1;268=1;269=1;270=1;271=1;272=1;273=1;274=1;275=1;277=1;278=1;279=1;280=1;281=1;282=1;283=1;284=1;285=1;286=1;287=1;290=1;293=1;294=1;295=1;296=1;297=1;298=1;299=1;300=1;301=1;302=1;303=1;304=1;305=1;306=1;307=1;308=1;310=1;311=1;313=1;314=1;315=1;316=1;317=1;318=1;319=1;320=1;322=1;323=1;324=1;325=1;326=1;327=1;330=1;331=1;332=1;333=1;334=1;335=1;336=1;337=1;338=1;340=1;345=1;346=1;347=1;348=1;349=1;352=1;353=1;354=1;355=1;357=1;359=1;360=1;361=1;362=1;363=1;365=1;366=1;367=1;370=1;371=1;372=1;373=1;374=1;375=1;376=1;377=1;378=1;379=1;380=1;382=1;383=1;384=1;385=1;386=1;387=1;388=1;389=1;390=1;391=1;392=1;393=1;394=1;395=1;396=1;399=1;400=1;401=1;402=1;403=1;404=1;405=1;406=1;407=1;408=1;409=1;410=1;411=1;414=1;415=1;416=1;417=1;418=1;419=1;420=1;421=1;422=1;423=1;424=1;425=1;426=1;427=1;428=1;429=1;430=1;433=1;434=1;435=1;436=1;437=1;438=1;439=1;440=1;441=1;442=1;443=1;444=1;445=1;446=1;447=1;448=1;450=1;451=1;453=1;454=1;455=1;456=1;457=1;458=1;459=1;460=1;461=1;462=1;463=1;464=1;465=1;466=1;469=1;470=1;471=1;472=1;473=1;474=1;475=1;476=1;477=1;478=1;479=1;480=1;481=1;482=1;484=1;485=1;486=1;488=1;489=1;490=1;491=1;493=1;494=1;495=1;496=1;497=1;498=1;499=1;500=1;501=1;502=1;503=1;504=1;505=1;506=1;507=1;508=1;509=1;510=1;511=1;512=1;513=1;514=1;515=1;516=1;517=1;518=1;519=1;520=1;521=1;524=1;525=1;526=1;527=1;528=1;529=1;530=1;531=1;532=1;534=1;535=1;536=1;537=1;539=1;540=1;541=1;542=1;543=1;544=1;545=1;546=1;547=1;548=1;549=1;550=1;551=1;552=1;553=1;554=1;555=1;556=1;557=1;558=1;559=1;560=1;562=1;563=1;564=1;565=1;567=1;568=1;569=1;570=1;571=1;572=1;573=1;576=1;577=1;578=1;579=1;581=1;582=1;583=1;585=1;586=1;588=1;589=1;590=1;591=1;592=1;593=1;594=1;597=1;598=1;601=1;602=1;605=1;606=1;608=1;609=1;610=1;611=1;613=1;615=1;616=1;618=1;619=1;620=1;621=1;622=1;623=1;624=1;625=1;628=1;629=1;631=1;632=1;633=1;634=1;636=1;637=1;640=1;641=1;642=1;644=1;645=1;646=1;647=1;648=1;649=1;651=1;652=1;655=1;656=1;657=1;660=1;661=1;662=1;663=1;664=1;665=1;666=1;668=1;669=1;670=1;671=1;672=1;674=1;675=1;676=1;677=1;678=1;679=1;680=1;681=1;684=1;685=1;686=1;687=1;688=1;689=1;690=1;691=1;694=1;695=1;696=1;697=1;700=1;701=1;702=1;704=1;705=1;706=1;707=1;709=1;712=1;713=1;716=1;719=1;720=1;721=1;723=1;724=1;725=1;726=1;727=1;728=1;730=1;731=1;732=1;733=1;734=1;735=1;738=1;739=1;740=1;742=1;743=1;744=1;745=1;746=1;747=1;748=1;749=1;750=1;751=1;752=1;753=1;754=1;755=1;756=1;758=1;759=1;760=1;761=1;764=1;765=1;766=1;767=1;769=1;770=1;771=1;772=1;773=1;774=1;775=1;776=1;777=1;778=1;779=1;780=1;781=1;782=1;783=1;784=1;785=1;786=1;787=1;788=1;789=1;790=1;791=1;792=1;793=1;794=1;795=1;796=1;797=1;798=1;799=1;800=1;802=1;803=1;804=1;806=1;807=1;808=1;809=1;810=1
\ No newline at end of file
diff --git a/src/src/build/sonar/scanner-report/measures-20.pb b/src/src/build/sonar/scanner-report/measures-20.pb
new file mode 100644
index 0000000..701dac9
--- /dev/null
+++ b/src/src/build/sonar/scanner-report/measures-20.pb
@@ -0,0 +1,15 @@
+
+classes
+ functions
+
+complexity$
+
comment_lines
+
+statements_
+ncloc
+cognitive_complexity"
+executable_lines_data2
+46=1;47=1;48=1;49=1;50=1;51=1;52=1;53=1;55=1;57=1;58=1;59=1;60=1;61=1;62=1;63=1;65=1;69=1;70=1;71=1;74=1;75=1;76=1;77=1;80=1;81=1;84=1;85=1;88=1;92=1;93=1;96=1;97=1;100=1;104=1;105=1;108=1;109=1;117=1;118=1;119=1;120=1;123=1;125=1;126=1;127=1;130=1;145=1;146=1;147=1;148=1;149=1;152=1;156=1;157=1;159=1;160=1;163=1;164=1;166=1;167=1;170=1;171=1;172=1;173=1;176=1;177=1;178=1;179=1;185=1;186=1;189=1;190=1;192=1;193=1;194=1;195=1;196=1;197=1;199=1;200=1;201=1;202=1;203=1;204=1;206=1;207=1;208=1;209=1;211=1;214=1;215=1;216=1;217=1;218=1;219=1;221=1;222=1;223=1;224=1;225=1;226=1;228=1;229=1;230=1;231=1;233=1;236=1;238=1;239=1;240=1;241=1;242=1;243=1;244=1;245=1;246=1;247=1;248=1;250=1
+
+ncloc_data2
+17=1;18=1;19=1;20=1;21=1;22=1;23=1;24=1;25=1;26=1;28=1;29=1;30=1;31=1;32=1;34=1;37=1;38=1;39=1;40=1;44=1;46=1;47=1;48=1;49=1;50=1;51=1;52=1;53=1;55=1;56=1;57=1;58=1;59=1;60=1;61=1;62=1;63=1;64=1;65=1;66=1;68=1;69=1;70=1;71=1;73=1;74=1;75=1;76=1;77=1;79=1;80=1;81=1;83=1;84=1;85=1;87=1;88=1;89=1;91=1;92=1;93=1;95=1;96=1;97=1;99=1;100=1;101=1;103=1;104=1;105=1;106=1;108=1;109=1;110=1;117=1;118=1;119=1;120=1;122=1;123=1;125=1;126=1;127=1;128=1;130=1;131=1;133=1;134=1;136=1;138=1;140=1;142=1;144=1;145=1;146=1;147=1;148=1;149=1;151=1;152=1;153=1;155=1;156=1;157=1;158=1;159=1;160=1;162=1;163=1;164=1;165=1;166=1;167=1;169=1;170=1;171=1;172=1;173=1;175=1;176=1;177=1;178=1;179=1;181=1;185=1;186=1;187=1;189=1;190=1;192=1;193=1;194=1;195=1;196=1;197=1;198=1;199=1;200=1;201=1;202=1;203=1;204=1;205=1;206=1;207=1;208=1;209=1;210=1;211=1;212=1;214=1;215=1;216=1;217=1;218=1;219=1;220=1;221=1;222=1;223=1;224=1;225=1;226=1;227=1;228=1;229=1;230=1;231=1;232=1;233=1;234=1;236=1;237=1;238=1;239=1;240=1;241=1;242=1;243=1;244=1;245=1;246=1;247=1;248=1;249=1;250=1;251=1;252=1;253=1;254=1
\ No newline at end of file
diff --git a/src/src/build/sonar/scanner-report/measures-21.pb b/src/src/build/sonar/scanner-report/measures-21.pb
new file mode 100644
index 0000000..bd9fdd8
--- /dev/null
+++ b/src/src/build/sonar/scanner-report/measures-21.pb
@@ -0,0 +1,15 @@
+
+classes
+ functions%
+
+complexityA
+
comment_lines
+
+statementst
+ncloc
+cognitive_complexity0
+executable_lines_data2
+256=1;257=1;258=1;259=1;261=1;263=1;266=1;267=1;268=1;270=1;271=1;273=1;276=1;277=1;278=1;280=1;283=1;284=1;285=1;287=1;290=1;291=1;292=1;294=1;297=1;298=1;299=1;300=1;303=1;307=1;311=1;315=1;319=1;67=1;323=1;68=1;69=1;70=1;71=1;327=1;72=1;73=1;74=1;331=1;77=1;78=1;79=1;335=1;80=1;81=1;82=1;83=1;339=1;343=1;347=1;352=1;353=1;354=1;355=1;356=1;357=1;358=1;359=1;364=1;365=1;110=1;366=1;111=1;112=1;113=1;369=1;114=1;370=1;115=1;371=1;116=1;117=1;118=1;119=1;123=1;124=1;125=1;126=1;127=1;128=1;129=1;132=1;133=1;134=1;136=1;137=1;138=1;139=1;140=1;141=1;142=1;143=1;146=1;148=1;149=1;151=1;152=1;155=1;156=1;157=1;158=1;160=1;161=1;163=1;164=1;165=1;166=1;167=1;168=1;169=1;171=1;173=1;175=1;177=1;178=1;180=1;184=1;185=1;186=1;187=1;188=1;192=1;196=1;197=1;198=1;199=1;200=1;204=1;209=1;210=1;211=1;212=1;214=1;216=1;221=1;225=1;226=1;227=1;229=1;234=1;235=1;238=1;239=1;240=1;242=1;243=1;245=1;248=1;249=1;250=1;251=1;253=1
+
+ncloc_data2
+
17=1;19=1;20=1;21=1;22=1;23=1;24=1;26=1;27=1;28=1;29=1;30=1;31=1;32=1;34=1;37=1;39=1;41=1;43=1;45=1;47=1;49=1;51=1;53=1;55=1;57=1;59=1;61=1;63=1;65=1;67=1;68=1;69=1;70=1;71=1;72=1;73=1;74=1;75=1;77=1;78=1;79=1;80=1;81=1;82=1;83=1;84=1;86=1;88=1;90=1;92=1;94=1;96=1;98=1;100=1;102=1;104=1;109=1;110=1;111=1;112=1;113=1;114=1;115=1;116=1;117=1;118=1;119=1;122=1;123=1;124=1;125=1;126=1;127=1;128=1;129=1;131=1;132=1;133=1;134=1;136=1;137=1;138=1;139=1;140=1;141=1;142=1;143=1;145=1;146=1;147=1;148=1;149=1;150=1;151=1;152=1;154=1;155=1;156=1;157=1;158=1;160=1;161=1;162=1;163=1;164=1;165=1;166=1;167=1;168=1;169=1;170=1;171=1;172=1;173=1;174=1;175=1;176=1;177=1;178=1;179=1;180=1;182=1;183=1;184=1;185=1;186=1;187=1;188=1;189=1;191=1;192=1;193=1;195=1;196=1;197=1;198=1;199=1;200=1;201=1;202=1;204=1;209=1;210=1;211=1;212=1;213=1;214=1;215=1;216=1;217=1;218=1;220=1;221=1;222=1;224=1;225=1;226=1;227=1;228=1;229=1;230=1;231=1;233=1;234=1;235=1;237=1;238=1;239=1;240=1;241=1;242=1;243=1;244=1;245=1;247=1;248=1;249=1;250=1;251=1;252=1;253=1;255=1;256=1;257=1;258=1;259=1;260=1;261=1;262=1;263=1;265=1;266=1;267=1;268=1;269=1;270=1;271=1;272=1;273=1;275=1;276=1;277=1;278=1;279=1;280=1;282=1;283=1;284=1;285=1;286=1;287=1;289=1;290=1;291=1;292=1;293=1;294=1;296=1;297=1;298=1;299=1;300=1;302=1;303=1;304=1;306=1;307=1;308=1;310=1;311=1;312=1;314=1;315=1;316=1;318=1;319=1;320=1;322=1;323=1;324=1;326=1;327=1;328=1;330=1;331=1;332=1;334=1;335=1;336=1;338=1;339=1;340=1;342=1;343=1;344=1;346=1;347=1;348=1;350=1;351=1;352=1;353=1;354=1;355=1;356=1;357=1;358=1;359=1;360=1;362=1;363=1;364=1;365=1;366=1;368=1;369=1;370=1;371=1;372=1;376=1;381=1;386=1;393=1;394=1;395=1;396=1
\ No newline at end of file
diff --git a/src/src/build/sonar/scanner-report/measures-22.pb b/src/src/build/sonar/scanner-report/measures-22.pb
new file mode 100644
index 0000000..a8b31cb
--- /dev/null
+++ b/src/src/build/sonar/scanner-report/measures-22.pb
@@ -0,0 +1,15 @@
+
+classes
+ functions
+
+complexity'
+
comment_lines
+
+statementsk
+ncloc
+cognitive_complexityD
+executable_lines_data2
+256=1;257=1;259=1;263=1;264=1;265=1;266=1;267=1;269=1;270=1;272=1;273=1;274=1;276=1;277=1;278=1;280=1;282=1;284=1;292=1;293=1;294=1;295=1;296=1;298=1;299=1;300=1;302=1;47=1;303=1;48=1;305=1;50=1;307=1;308=1;309=1;311=1;312=1;313=1;315=1;316=1;317=1;319=1;71=1;327=1;72=1;328=1;329=1;330=1;75=1;331=1;332=1;333=1;334=1;79=1;335=1;338=1;83=1;339=1;341=1;342=1;87=1;343=1;344=1;346=1;91=1;92=1;348=1;93=1;349=1;94=1;95=1;351=1;352=1;354=1;355=1;357=1;104=1;105=1;106=1;107=1;108=1;109=1;110=1;131=1;132=1;133=1;134=1;135=1;138=1;146=1;147=1;148=1;149=1;151=1;152=1;155=1;156=1;157=1;159=1;160=1;161=1;163=1;165=1;171=1;172=1;173=1;174=1;176=1;177=1;179=1;180=1;182=1;183=1;184=1;186=1;187=1;188=1;191=1;192=1;193=1;195=1;196=1;197=1;199=1;200=1;201=1;202=1;203=1;206=1;208=1;212=1;213=1;215=1;216=1;217=1;218=1;224=1;225=1;226=1;229=1;230=1;231=1;232=1;235=1;236=1;237=1;238=1;239=1;240=1;242=1;243=1;246=1;247=1;248=1;250=1;252=1;253=1;255=1
+
+ncloc_data2
+17=1;19=1;20=1;21=1;22=1;23=1;24=1;25=1;26=1;28=1;29=1;30=1;31=1;32=1;34=1;35=1;36=1;37=1;38=1;41=1;42=1;44=1;46=1;47=1;48=1;49=1;50=1;51=1;58=1;60=1;62=1;64=1;66=1;68=1;70=1;71=1;72=1;74=1;75=1;76=1;78=1;79=1;80=1;82=1;83=1;84=1;86=1;87=1;88=1;90=1;91=1;92=1;93=1;94=1;95=1;96=1;98=1;100=1;102=1;104=1;105=1;106=1;107=1;108=1;109=1;110=1;111=1;113=1;115=1;117=1;119=1;121=1;122=1;123=1;124=1;126=1;127=1;128=1;130=1;131=1;132=1;133=1;134=1;135=1;137=1;138=1;139=1;144=1;146=1;147=1;148=1;149=1;151=1;152=1;153=1;155=1;156=1;157=1;159=1;160=1;161=1;162=1;163=1;164=1;165=1;170=1;171=1;172=1;173=1;174=1;176=1;177=1;178=1;179=1;180=1;182=1;183=1;184=1;186=1;187=1;188=1;189=1;191=1;192=1;193=1;195=1;196=1;197=1;198=1;199=1;200=1;201=1;202=1;203=1;204=1;205=1;206=1;207=1;208=1;209=1;211=1;212=1;213=1;214=1;215=1;216=1;217=1;218=1;223=1;224=1;225=1;226=1;227=1;229=1;230=1;231=1;232=1;233=1;235=1;236=1;237=1;238=1;239=1;240=1;242=1;243=1;244=1;246=1;247=1;248=1;249=1;250=1;251=1;252=1;253=1;254=1;255=1;256=1;257=1;258=1;259=1;260=1;263=1;264=1;265=1;266=1;267=1;269=1;270=1;271=1;272=1;273=1;274=1;276=1;277=1;278=1;279=1;280=1;281=1;282=1;284=1;285=1;290=1;291=1;292=1;293=1;294=1;295=1;296=1;297=1;298=1;299=1;300=1;302=1;303=1;305=1;307=1;308=1;309=1;311=1;312=1;313=1;315=1;316=1;317=1;319=1;320=1;321=1;326=1;327=1;328=1;329=1;330=1;331=1;332=1;333=1;334=1;335=1;337=1;338=1;339=1;340=1;341=1;342=1;343=1;344=1;345=1;346=1;347=1;348=1;349=1;351=1;352=1;354=1;355=1;357=1;358=1;359=1;362=1
\ No newline at end of file
diff --git a/src/src/build/sonar/scanner-report/measures-23.pb b/src/src/build/sonar/scanner-report/measures-23.pb
new file mode 100644
index 0000000..c8524b3
--- /dev/null
+++ b/src/src/build/sonar/scanner-report/measures-23.pb
@@ -0,0 +1,15 @@
+
+classes
+ functions
+
+complexity.
+
comment_lines
+
+statements
+ncloc
+cognitive_complexity;
+executable_lines_data2
+257=1;258=1;259=1;260=1;262=1;264=1;268=1;269=1;270=1;271=1;272=1;274=1;275=1;276=1;277=1;279=1;280=1;282=1;286=1;287=1;288=1;289=1;290=1;293=1;41=1;42=1;43=1;45=1;46=1;47=1;50=1;51=1;52=1;53=1;56=1;57=1;58=1;59=1;61=1;62=1;63=1;64=1;66=1;67=1;68=1;69=1;70=1;71=1;72=1;76=1;77=1;78=1;79=1;80=1;81=1;85=1;86=1;87=1;90=1;91=1;92=1;93=1;94=1;95=1;96=1;97=1;100=1;101=1;102=1;103=1;105=1;106=1;107=1;108=1;109=1;110=1;111=1;118=1;119=1;120=1;121=1;122=1;124=1;125=1;126=1;128=1;129=1;130=1;132=1;133=1;136=1;140=1;141=1;142=1;143=1;144=1;146=1;147=1;148=1;149=1;151=1;153=1;157=1;158=1;160=1;161=1;162=1;163=1;165=1;167=1;171=1;172=1;174=1;175=1;176=1;177=1;179=1;181=1;185=1;186=1;187=1;188=1;189=1;190=1;191=1;192=1;193=1;195=1;197=1;201=1;202=1;203=1;204=1;205=1;207=1;208=1;209=1;210=1;213=1;214=1;215=1;216=1;217=1;218=1;219=1;220=1;222=1;224=1;228=1;229=1;230=1;231=1;232=1;234=1;236=1;237=1;238=1;240=1;241=1;243=1;247=1;248=1;249=1;250=1;251=1;252=1;254=1;255=1
+
+ncloc_data2
+17=1;19=1;20=1;21=1;22=1;23=1;24=1;25=1;26=1;27=1;29=1;30=1;31=1;32=1;34=1;35=1;38=1;39=1;40=1;41=1;42=1;43=1;44=1;45=1;46=1;47=1;48=1;50=1;51=1;52=1;53=1;54=1;55=1;56=1;57=1;58=1;59=1;60=1;61=1;62=1;63=1;64=1;65=1;66=1;67=1;68=1;69=1;70=1;71=1;72=1;73=1;75=1;76=1;77=1;78=1;79=1;80=1;81=1;83=1;84=1;85=1;86=1;87=1;88=1;90=1;91=1;92=1;93=1;94=1;95=1;96=1;97=1;99=1;100=1;101=1;102=1;103=1;104=1;105=1;106=1;107=1;108=1;109=1;110=1;111=1;112=1;117=1;118=1;119=1;120=1;121=1;122=1;124=1;125=1;126=1;127=1;128=1;129=1;130=1;131=1;132=1;133=1;134=1;135=1;136=1;137=1;139=1;140=1;141=1;142=1;143=1;144=1;146=1;147=1;148=1;149=1;150=1;151=1;152=1;153=1;154=1;156=1;157=1;158=1;160=1;161=1;162=1;163=1;164=1;165=1;166=1;167=1;168=1;170=1;171=1;172=1;174=1;175=1;176=1;177=1;178=1;179=1;180=1;181=1;182=1;184=1;185=1;186=1;187=1;188=1;189=1;190=1;191=1;192=1;193=1;194=1;195=1;196=1;197=1;198=1;200=1;201=1;202=1;203=1;204=1;205=1;207=1;208=1;209=1;210=1;211=1;212=1;213=1;214=1;215=1;216=1;217=1;218=1;219=1;220=1;221=1;222=1;223=1;224=1;225=1;227=1;228=1;229=1;230=1;231=1;232=1;234=1;235=1;236=1;237=1;238=1;239=1;240=1;241=1;242=1;243=1;244=1;246=1;247=1;248=1;249=1;250=1;251=1;252=1;254=1;255=1;256=1;257=1;258=1;259=1;260=1;261=1;262=1;263=1;264=1;265=1;267=1;268=1;269=1;270=1;271=1;272=1;274=1;275=1;276=1;277=1;278=1;279=1;280=1;281=1;282=1;283=1;285=1;286=1;287=1;288=1;289=1;290=1;291=1;292=1;293=1;294=1;295=1;296=1
\ No newline at end of file
diff --git a/src/src/build/sonar/scanner-report/measures-24.pb b/src/src/build/sonar/scanner-report/measures-24.pb
new file mode 100644
index 0000000..76a880d
Binary files /dev/null and b/src/src/build/sonar/scanner-report/measures-24.pb differ
diff --git a/src/src/build/sonar/scanner-report/measures-25.pb b/src/src/build/sonar/scanner-report/measures-25.pb
new file mode 100644
index 0000000..7130f94
--- /dev/null
+++ b/src/src/build/sonar/scanner-report/measures-25.pb
@@ -0,0 +1,18 @@
+
+classes
+ functions
+
+complexity*
+
comment_lines]
+
+statements
+ncloc
+cognitive_complexity!
+executable_lines_data2
+266=1;267=1;268=1;269=1;270=1;272=1;273=1;275=1;276=1;277=1;278=1;279=1;280=1;281=1;26=1;282=1;27=1;28=1;284=1;285=1;30=1;286=1;31=1;287=1;32=1;288=1;33=1;34=1;290=1;291=1;36=1;293=1;38=1;294=1;295=1;40=1;296=1;41=1;297=1;42=1;43=1;44=1;300=1;52=1;53=1;309=1;54=1;55=1;311=1;56=1;57=1;313=1;58=1;59=1;315=1;61=1;317=1;62=1;63=1;319=1;64=1;320=1;65=1;321=1;66=1;323=1;68=1;324=1;325=1;326=1;328=1;80=1;82=1;84=1;340=1;85=1;341=1;86=1;87=1;343=1;88=1;344=1;345=1;90=1;348=1;350=1;351=1;353=1;354=1;355=1;356=1;357=1;105=1;106=1;107=1;109=1;113=1;114=1;120=1;123=1;132=1;133=1;134=1;137=1;140=1;142=1;143=1;144=1;145=1;147=1;156=1;157=1;158=1;160=1;166=1;167=1;168=1;169=1;170=1;171=1;172=1;179=1;180=1;182=1;183=1;184=1;187=1;189=1;190=1;192=1;193=1;194=1;197=1;198=1;204=1;205=1;206=1;207=1;208=1;209=1;210=1;211=1;213=1;215=1;216=1;217=1;220=1;221=1;230=1;232=1;233=1;234=1;236=1;237=1;238=1;240=1;241=1;243=1;244=1;245=1;246=1;247=1;249=1;250=1;251=1;253=1;255=1
+
+
+ncloc_data2
+
+
+1=1;3=1;4=1;5=1;6=1;7=1;8=1;9=1;10=1;11=1;13=1;14=1;15=1;16=1;21=1;25=1;26=1;27=1;28=1;30=1;31=1;32=1;33=1;34=1;36=1;37=1;38=1;39=1;40=1;41=1;42=1;43=1;44=1;45=1;51=1;52=1;53=1;54=1;55=1;56=1;57=1;58=1;59=1;60=1;61=1;62=1;63=1;64=1;65=1;66=1;67=1;68=1;69=1;78=1;80=1;82=1;83=1;84=1;85=1;86=1;87=1;88=1;90=1;92=1;102=1;103=1;105=1;106=1;107=1;109=1;113=1;114=1;120=1;121=1;123=1;124=1;131=1;132=1;133=1;134=1;137=1;140=1;142=1;143=1;144=1;145=1;146=1;147=1;148=1;155=1;156=1;157=1;158=1;159=1;160=1;165=1;166=1;167=1;168=1;169=1;170=1;171=1;172=1;175=1;176=1;179=1;180=1;182=1;183=1;184=1;185=1;187=1;189=1;190=1;192=1;193=1;194=1;197=1;198=1;199=1;202=1;203=1;204=1;205=1;206=1;207=1;208=1;209=1;210=1;211=1;213=1;214=1;215=1;216=1;217=1;218=1;220=1;221=1;222=1;229=1;230=1;232=1;233=1;234=1;236=1;237=1;238=1;240=1;241=1;243=1;244=1;245=1;246=1;247=1;248=1;249=1;250=1;251=1;253=1;255=1;256=1;265=1;266=1;267=1;268=1;269=1;270=1;271=1;272=1;273=1;275=1;276=1;277=1;278=1;279=1;280=1;281=1;282=1;284=1;285=1;286=1;287=1;288=1;289=1;290=1;291=1;293=1;294=1;295=1;296=1;297=1;300=1;301=1;308=1;309=1;311=1;313=1;315=1;317=1;319=1;320=1;321=1;323=1;324=1;325=1;326=1;327=1;328=1;329=1;338=1;340=1;341=1;343=1;344=1;345=1;346=1;348=1;350=1;351=1;353=1;354=1;355=1;356=1;357=1;358=1;359=1;360=1
\ No newline at end of file
diff --git a/src/src/build/sonar/scanner-report/measures-26.pb b/src/src/build/sonar/scanner-report/measures-26.pb
new file mode 100644
index 0000000..e21cb57
--- /dev/null
+++ b/src/src/build/sonar/scanner-report/measures-26.pb
@@ -0,0 +1,15 @@
+
+classes
+ functions
+
+complexity
+
comment_lines
+
+statements
+ncloc
+cognitive_complexity
+executable_lines_data2
+131=1;135=1;139=1;144=1;145=1;146=1;147=1;148=1;149=1;153=1;156=1;157=1;158=1;159=1;160=1;161=1;37=1;165=1;170=1;171=1;44=1;172=1;173=1;174=1;47=1;48=1;49=1;50=1;51=1;52=1;55=1;183=1;56=1;184=1;57=1;58=1;186=1;59=1;60=1;190=1;64=1;68=1;73=1;74=1;76=1;77=1;78=1;80=1;81=1;82=1;85=1;90=1;91=1;92=1;93=1;94=1;95=1;98=1;99=1;100=1;101=1;102=1;103=1;106=1;107=1;108=1;109=1;110=1;111=1;114=1;115=1;116=1;117=1;118=1;119=1;123=1;127=1
+
+ncloc_data2
+17=1;20=1;21=1;22=1;24=1;26=1;27=1;29=1;31=1;32=1;33=1;34=1;35=1;37=1;39=1;40=1;41=1;42=1;44=1;46=1;47=1;48=1;49=1;50=1;51=1;52=1;53=1;55=1;56=1;57=1;58=1;59=1;60=1;61=1;63=1;64=1;65=1;67=1;68=1;69=1;70=1;72=1;73=1;74=1;75=1;76=1;77=1;78=1;80=1;81=1;82=1;84=1;85=1;86=1;87=1;89=1;90=1;91=1;92=1;93=1;94=1;95=1;96=1;98=1;99=1;100=1;101=1;102=1;103=1;104=1;106=1;107=1;108=1;109=1;110=1;111=1;112=1;114=1;115=1;116=1;117=1;118=1;119=1;120=1;122=1;123=1;124=1;126=1;127=1;128=1;130=1;131=1;132=1;134=1;135=1;136=1;138=1;139=1;140=1;141=1;143=1;144=1;145=1;146=1;147=1;148=1;149=1;150=1;152=1;153=1;154=1;156=1;157=1;158=1;159=1;160=1;161=1;162=1;164=1;165=1;166=1;167=1;169=1;170=1;171=1;172=1;173=1;174=1;175=1;177=1;183=1;184=1;185=1;186=1;187=1;189=1;190=1;191=1;192=1;193=1;194=1
\ No newline at end of file
diff --git a/src/src/build/sonar/scanner-report/measures-27.pb b/src/src/build/sonar/scanner-report/measures-27.pb
new file mode 100644
index 0000000..a471757
--- /dev/null
+++ b/src/src/build/sonar/scanner-report/measures-27.pb
@@ -0,0 +1,15 @@
+
+classes
+ functions
+
+complexity
+
comment_lines
+
+statements'
+nclocA
+cognitive_complexity
+executable_lines_data2
+65=1;66=1;67=1;68=1;69=1;70=1;71=1;72=1;73=1;74=1;82=1;83=1;84=1;85=1;86=1;23=1;87=1;24=1;88=1;25=1;89=1;26=1;90=1;91=1;92=1;93=1;94=1;95=1;35=1;36=1;37=1;38=1;39=1;48=1;50=1;51=1;52=1;53=1;54=1;55=1;56=1;57=1;58=1
+
+ncloc_data2
+1=1;3=1;4=1;5=1;6=1;7=1;8=1;9=1;14=1;21=1;22=1;23=1;24=1;25=1;26=1;27=1;34=1;35=1;36=1;37=1;38=1;39=1;40=1;47=1;48=1;49=1;50=1;51=1;52=1;53=1;54=1;55=1;56=1;57=1;58=1;59=1;64=1;65=1;66=1;67=1;68=1;69=1;70=1;71=1;72=1;73=1;74=1;75=1;81=1;82=1;83=1;84=1;85=1;86=1;87=1;88=1;89=1;90=1;91=1;92=1;93=1;94=1;95=1;96=1;97=1;98=1
\ No newline at end of file
diff --git a/src/src/build/sonar/scanner-report/measures-28.pb b/src/src/build/sonar/scanner-report/measures-28.pb
new file mode 100644
index 0000000..bf9e8d4
--- /dev/null
+++ b/src/src/build/sonar/scanner-report/measures-28.pb
@@ -0,0 +1,15 @@
+
+classes
+ functions
+
+complexity
+
comment_lines
+
+statements7
+nclocz
+cognitive_complexity
+executable_lines_data2
+128=1;129=1;132=1;133=1;134=1;135=1;136=1;137=1;139=1;140=1;143=1;144=1;145=1;146=1;147=1;148=1;153=1;156=1;157=1;158=1;161=1;162=1;163=1;164=1;166=1;54=1;55=1;57=1;58=1;60=1;61=1;62=1;63=1;64=1;67=1;70=1;71=1;72=1;73=1;74=1;75=1;77=1;79=1;81=1;82=1;83=1;84=1;85=1;87=1;89=1;92=1;93=1;97=1;99=1;100=1;102=1;103=1;105=1;108=1;109=1;110=1;111=1;112=1;115=1;116=1;119=1;120=1;123=1;124=1;127=1
+
+ncloc_data2
+17=1;19=1;20=1;21=1;22=1;23=1;24=1;25=1;26=1;27=1;28=1;29=1;30=1;31=1;32=1;33=1;34=1;35=1;37=1;38=1;39=1;41=1;43=1;46=1;47=1;48=1;49=1;50=1;52=1;53=1;54=1;55=1;57=1;58=1;60=1;61=1;62=1;63=1;64=1;65=1;67=1;69=1;70=1;71=1;72=1;73=1;74=1;75=1;77=1;78=1;79=1;81=1;82=1;83=1;84=1;85=1;86=1;87=1;88=1;89=1;91=1;92=1;93=1;94=1;96=1;97=1;99=1;100=1;102=1;103=1;104=1;105=1;106=1;107=1;108=1;109=1;110=1;111=1;112=1;115=1;116=1;119=1;120=1;123=1;124=1;127=1;128=1;129=1;131=1;132=1;133=1;134=1;135=1;136=1;137=1;138=1;139=1;140=1;142=1;143=1;144=1;145=1;146=1;147=1;148=1;149=1;150=1;151=1;152=1;153=1;155=1;156=1;157=1;158=1;160=1;161=1;162=1;163=1;164=1;165=1;166=1;167=1;168=1
\ No newline at end of file
diff --git a/src/src/build/sonar/scanner-report/measures-29.pb b/src/src/build/sonar/scanner-report/measures-29.pb
new file mode 100644
index 0000000..23d0c57
Binary files /dev/null and b/src/src/build/sonar/scanner-report/measures-29.pb differ
diff --git a/src/src/build/sonar/scanner-report/measures-30.pb b/src/src/build/sonar/scanner-report/measures-30.pb
new file mode 100644
index 0000000..ac4415b
Binary files /dev/null and b/src/src/build/sonar/scanner-report/measures-30.pb differ
diff --git a/src/src/build/sonar/scanner-report/measures-31.pb b/src/src/build/sonar/scanner-report/measures-31.pb
new file mode 100644
index 0000000..f60ff1d
--- /dev/null
+++ b/src/src/build/sonar/scanner-report/measures-31.pb
@@ -0,0 +1,15 @@
+
+classes
+ functions
+
+complexityO
+
comment_lines%
+
+statements
+ncloc
+cognitive_complexity'
+executable_lines_data2
+ 39=1;55=1;61=1;67=1;70=1;71=1;72=1;73=1;76=1;79=1;80=1;81=1;82=1;83=1;84=1;85=1;86=1;87=1;88=1;89=1;91=1;92=1;93=1;94=1;97=1;98=1;99=1;100=1;101=1;102=1;103=1;104=1;107=1;108=1;109=1;110=1;111=1;112=1;113=1;115=1;118=1;121=1;122=1;123=1;124=1;125=1;126=1;127=1;129=1;130=1;131=1;132=1;133=1;134=1;135=1;136=1;138=1;139=1;142=1;143=1;144=1;147=1;150=1;151=1;152=1;154=1;156=1;157=1;158=1;167=1;168=1;171=1;172=1;175=1;176=1;177=1;178=1;179=1;181=1;182=1;183=1;184=1;186=1;187=1;188=1;189=1;190=1;191=1;192=1;194=1;195=1;196=1;197=1;198=1;199=1;202=1;203=1;204=1;206=1;209=1;211=1;214=1;215=1;219=1;222=1;223=1;224=1;225=1;226=1;227=1;228=1;232=1;241=1;250=1;251=1;252=1;253=1;254=1;267=1;268=1;269=1;270=1;271=1;272=1;280=1;289=1;292=1;293=1;294=1;295=1;303=1;312=1;315=1;316=1;317=1;318=1;326=1;335=1;338=1;339=1;340=1;341=1;348=1;352=1;353=1;355=1;356=1;357=1;359=1;370=1;373=1;374=1;375=1;376=1;377=1;378=1;381=1;382=1;383=1;386=1;388=1;389=1;390=1;398=1;405=1;408=1;409=1;410=1;411=1;417=1;426=1;429=1;430=1;431=1;432=1;433=1;434=1;435=1;438=1;439=1;440=1;441=1;442=1;443=1;444=1;445=1;446=1;447=1;448=1;449=1;452=1;453=1;455=1;456=1;457=1;459=1;462=1;463=1;464=1;466=1;467=1;469=1;476=1;477=1;480=1;481=1;482=1;484=1
+
+ncloc_data2
+17=1;19=1;20=1;22=1;25=1;26=1;27=1;28=1;29=1;31=1;33=1;35=1;36=1;37=1;38=1;39=1;40=1;41=1;42=1;43=1;44=1;45=1;46=1;47=1;49=1;50=1;51=1;52=1;53=1;55=1;57=1;59=1;61=1;63=1;65=1;67=1;68=1;69=1;70=1;71=1;72=1;73=1;74=1;76=1;77=1;78=1;79=1;80=1;81=1;82=1;83=1;84=1;85=1;86=1;87=1;88=1;89=1;90=1;91=1;92=1;93=1;94=1;95=1;96=1;97=1;98=1;99=1;100=1;101=1;102=1;103=1;104=1;105=1;106=1;107=1;108=1;109=1;110=1;111=1;112=1;113=1;114=1;115=1;116=1;118=1;119=1;120=1;121=1;122=1;123=1;124=1;125=1;126=1;127=1;128=1;129=1;130=1;131=1;132=1;133=1;134=1;135=1;136=1;137=1;138=1;139=1;140=1;141=1;142=1;143=1;144=1;145=1;147=1;148=1;149=1;150=1;151=1;152=1;153=1;154=1;155=1;156=1;157=1;158=1;159=1;161=1;162=1;163=1;164=1;166=1;167=1;168=1;170=1;171=1;172=1;174=1;175=1;176=1;177=1;178=1;179=1;181=1;182=1;183=1;184=1;186=1;187=1;188=1;189=1;190=1;191=1;192=1;194=1;195=1;196=1;197=1;198=1;199=1;202=1;203=1;204=1;206=1;209=1;211=1;214=1;215=1;217=1;218=1;219=1;220=1;221=1;222=1;223=1;224=1;225=1;226=1;227=1;228=1;230=1;231=1;232=1;233=1;240=1;241=1;242=1;249=1;250=1;251=1;252=1;253=1;254=1;265=1;266=1;267=1;268=1;269=1;270=1;271=1;272=1;279=1;280=1;281=1;288=1;289=1;290=1;291=1;292=1;293=1;294=1;295=1;302=1;303=1;304=1;311=1;312=1;313=1;314=1;315=1;316=1;317=1;318=1;325=1;326=1;327=1;334=1;335=1;336=1;337=1;338=1;339=1;340=1;341=1;347=1;348=1;349=1;351=1;352=1;353=1;354=1;355=1;356=1;357=1;358=1;359=1;360=1;361=1;362=1;369=1;370=1;371=1;372=1;373=1;374=1;375=1;376=1;377=1;378=1;379=1;380=1;381=1;382=1;383=1;384=1;385=1;386=1;387=1;388=1;389=1;390=1;397=1;398=1;399=1;404=1;405=1;406=1;407=1;408=1;409=1;410=1;411=1;416=1;417=1;418=1;425=1;426=1;427=1;428=1;429=1;430=1;431=1;432=1;433=1;434=1;435=1;437=1;438=1;439=1;440=1;441=1;442=1;443=1;444=1;445=1;446=1;447=1;448=1;449=1;451=1;452=1;453=1;454=1;455=1;456=1;457=1;458=1;459=1;461=1;462=1;463=1;464=1;465=1;466=1;467=1;468=1;469=1;475=1;476=1;477=1;479=1;480=1;481=1;482=1;483=1;484=1;485=1;486=1
\ No newline at end of file
diff --git a/src/src/build/sonar/scanner-report/measures-32.pb b/src/src/build/sonar/scanner-report/measures-32.pb
new file mode 100644
index 0000000..8460954
Binary files /dev/null and b/src/src/build/sonar/scanner-report/measures-32.pb differ
diff --git a/src/src/build/sonar/scanner-report/measures-35.pb b/src/src/build/sonar/scanner-report/measures-35.pb
new file mode 100644
index 0000000..e506a2e
--- /dev/null
+++ b/src/src/build/sonar/scanner-report/measures-35.pb
@@ -0,0 +1,15 @@
+
+classes
+ functions
+
+complexity
+
comment_lines
+
+statements!
+nclocP
+cognitive_complexity
+executable_lines_data2
+64=1;65=1;68=1;69=1;70=1;71=1;72=1;77=1;78=1;79=1;80=1;82=1;84=1;86=1;89=1;90=1;91=1;92=1;94=1;96=1;97=1;99=1;100=1;101=1;38=1;103=1;40=1;42=1;44=1;45=1;47=1;48=1;49=1;50=1;53=1;55=1;57=1;59=1;63=1
+
+ncloc_data2
+1=1;3=1;4=1;5=1;6=1;7=1;8=1;9=1;10=1;11=1;12=1;13=1;14=1;15=1;16=1;17=1;18=1;19=1;21=1;23=1;25=1;27=1;29=1;31=1;33=1;35=1;36=1;37=1;38=1;40=1;42=1;44=1;45=1;47=1;48=1;49=1;50=1;51=1;52=1;53=1;55=1;57=1;59=1;60=1;61=1;63=1;64=1;65=1;66=1;68=1;69=1;70=1;71=1;72=1;73=1;74=1;75=1;77=1;78=1;79=1;80=1;82=1;84=1;86=1;87=1;88=1;89=1;90=1;91=1;92=1;94=1;96=1;97=1;98=1;99=1;100=1;101=1;102=1;103=1;104=1
\ No newline at end of file
diff --git a/src/src/build/sonar/scanner-report/measures-36.pb b/src/src/build/sonar/scanner-report/measures-36.pb
new file mode 100644
index 0000000..348200f
--- /dev/null
+++ b/src/src/build/sonar/scanner-report/measures-36.pb
@@ -0,0 +1,15 @@
+
+classes
+ functions
+
+complexity
+
comment_lines
+
+statements-
+ncloca
+cognitive_complexity
+executable_lines_data2
+30=1;31=1;32=1;33=1;37=1;38=1;40=1;42=1;44=1;46=1;47=1;48=1;50=1;52=1;53=1;56=1;60=1;61=1;62=1;64=1;65=1;67=1;69=1;70=1;72=1;74=1;75=1;76=1;78=1;80=1;81=1;85=1;89=1;91=1;92=1;93=1;94=1;97=1;98=1;102=1;103=1;108=1;109=1;110=1;112=1;114=1;115=1;116=1;117=1;118=1;119=1;120=1;121=1;122=1;123=1
+
+ncloc_data2
+1=1;3=1;4=1;5=1;6=1;8=1;9=1;10=1;11=1;12=1;13=1;14=1;15=1;16=1;17=1;18=1;19=1;20=1;21=1;23=1;24=1;25=1;26=1;27=1;28=1;29=1;30=1;31=1;32=1;33=1;35=1;36=1;37=1;38=1;40=1;42=1;44=1;46=1;47=1;48=1;50=1;52=1;53=1;56=1;57=1;58=1;60=1;61=1;62=1;64=1;65=1;66=1;67=1;69=1;70=1;72=1;74=1;75=1;76=1;77=1;78=1;80=1;81=1;82=1;83=1;85=1;86=1;87=1;89=1;90=1;91=1;92=1;93=1;94=1;96=1;97=1;98=1;101=1;102=1;103=1;106=1;108=1;109=1;110=1;111=1;112=1;114=1;115=1;116=1;117=1;118=1;119=1;120=1;121=1;122=1;123=1;124=1
\ No newline at end of file
diff --git a/src/src/build/sonar/scanner-report/measures-37.pb b/src/src/build/sonar/scanner-report/measures-37.pb
new file mode 100644
index 0000000..03791ad
--- /dev/null
+++ b/src/src/build/sonar/scanner-report/measures-37.pb
@@ -0,0 +1,15 @@
+
+classes
+ functions7
+
+complexity
+
comment_lines
+
+statements
+ncloc
+cognitive_complexity#
+executable_lines_data2#
+#1027=1;1028=1;1030=1;1033=1;1034=1;1035=1;1036=1;1040=1;1041=1;1044=1;1045=1;1049=1;1050=1;1051=1;1053=1;1056=1;1057=1;1058=1;1061=1;1062=1;1063=1;1064=1;1065=1;1066=1;1067=1;1069=1;1070=1;1072=1;1073=1;1074=1;1076=1;1077=1;1078=1;1079=1;1082=1;1083=1;1084=1;1085=1;1087=1;1088=1;1091=1;1092=1;1094=1;1097=1;1099=1;1100=1;1102=1;1104=1;1107=1;1109=1;1112=1;1113=1;1114=1;1115=1;1116=1;1118=1;1119=1;1120=1;1121=1;1122=1;1123=1;1127=1;1128=1;1132=1;1133=1;1135=1;1137=1;1139=1;1141=1;119=1;1143=1;1144=1;1145=1;122=1;1146=1;123=1;1147=1;124=1;125=1;1149=1;126=1;1151=1;1152=1;129=1;1153=1;1154=1;132=1;1156=1;133=1;1157=1;134=1;135=1;1159=1;136=1;1160=1;1161=1;1162=1;139=1;1164=1;142=1;1166=1;143=1;1167=1;144=1;1168=1;145=1;1170=1;1171=1;148=1;1173=1;1174=1;151=1;1175=1;152=1;1176=1;153=1;154=1;1181=1;1183=1;1184=1;1185=1;1187=1;1189=1;1190=1;1192=1;1194=1;1196=1;1197=1;1198=1;1200=1;1202=1;1203=1;1204=1;1205=1;1206=1;183=1;184=1;1209=1;1210=1;1211=1;1213=1;1215=1;1218=1;197=1;1221=1;198=1;1222=1;199=1;1223=1;200=1;1224=1;1225=1;1226=1;203=1;204=1;1228=1;205=1;1229=1;1230=1;1231=1;208=1;1232=1;209=1;1233=1;210=1;1234=1;1235=1;212=1;1236=1;213=1;1237=1;214=1;215=1;1239=1;217=1;1241=1;1242=1;220=1;1244=1;1245=1;222=1;1246=1;223=1;1247=1;1248=1;225=1;1249=1;1250=1;227=1;1251=1;229=1;1253=1;230=1;1254=1;232=1;1256=1;233=1;1260=1;237=1;238=1;1262=1;1264=1;241=1;242=1;1266=1;1267=1;1268=1;245=1;1269=1;246=1;1270=1;1271=1;249=1;1273=1;250=1;1274=1;1275=1;252=1;1278=1;1279=1;256=1;1280=1;258=1;259=1;260=1;1284=1;262=1;1286=1;263=1;1288=1;265=1;266=1;1290=1;1292=1;1293=1;1294=1;272=1;273=1;1297=1;274=1;1298=1;275=1;1299=1;1301=1;278=1;1302=1;279=1;1303=1;280=1;1304=1;281=1;282=1;1306=1;283=1;1307=1;284=1;285=1;1309=1;286=1;1310=1;287=1;1311=1;288=1;290=1;291=1;292=1;293=1;295=1;300=1;301=1;302=1;303=1;304=1;308=1;309=1;310=1;312=1;313=1;321=1;322=1;323=1;324=1;325=1;326=1;329=1;331=1;338=1;339=1;340=1;341=1;346=1;347=1;348=1;351=1;352=1;353=1;354=1;355=1;356=1;358=1;359=1;360=1;361=1;362=1;365=1;366=1;367=1;368=1;370=1;371=1;372=1;373=1;374=1;375=1;376=1;379=1;380=1;381=1;382=1;383=1;385=1;386=1;387=1;388=1;389=1;390=1;391=1;392=1;395=1;396=1;397=1;400=1;401=1;404=1;405=1;406=1;407=1;409=1;410=1;411=1;412=1;413=1;415=1;416=1;417=1;419=1;420=1;424=1;425=1;426=1;427=1;429=1;430=1;432=1;433=1;434=1;435=1;436=1;438=1;439=1;440=1;441=1;447=1;448=1;451=1;452=1;453=1;454=1;456=1;457=1;459=1;460=1;462=1;463=1;465=1;469=1;470=1;471=1;475=1;481=1;482=1;484=1;485=1;486=1;490=1;491=1;492=1;493=1;496=1;497=1;498=1;499=1;501=1;505=1;506=1;507=1;508=1;509=1;510=1;511=1;512=1;513=1;515=1;519=1;520=1;521=1;522=1;523=1;524=1;525=1;526=1;527=1;528=1;530=1;531=1;532=1;533=1;534=1;536=1;537=1;538=1;539=1;540=1;541=1;542=1;543=1;550=1;551=1;553=1;554=1;557=1;558=1;559=1;560=1;561=1;563=1;567=1;568=1;570=1;571=1;572=1;575=1;576=1;577=1;578=1;579=1;580=1;581=1;582=1;583=1;584=1;585=1;586=1;587=1;588=1;589=1;590=1;591=1;593=1;594=1;596=1;598=1;602=1;605=1;606=1;607=1;612=1;613=1;614=1;615=1;616=1;617=1;619=1;623=1;624=1;625=1;626=1;627=1;631=1;632=1;634=1;635=1;636=1;637=1;639=1;641=1;642=1;644=1;646=1;647=1;649=1;651=1;652=1;654=1;656=1;661=1;662=1;663=1;665=1;666=1;668=1;669=1;671=1;672=1;673=1;675=1;678=1;679=1;681=1;682=1;684=1;685=1;686=1;687=1;688=1;689=1;690=1;692=1;693=1;694=1;696=1;697=1;699=1;700=1;701=1;703=1;704=1;705=1;707=1;708=1;709=1;711=1;712=1;714=1;715=1;717=1;718=1;723=1;727=1;728=1;730=1;731=1;733=1;734=1;741=1;742=1;743=1;744=1;745=1;749=1;752=1;753=1;754=1;755=1;756=1;757=1;758=1;761=1;762=1;763=1;764=1;765=1;767=1;769=1;770=1;771=1;774=1;775=1;779=1;780=1;783=1;791=1;792=1;794=1;795=1;796=1;797=1;798=1;799=1;800=1;801=1;803=1;811=1;812=1;814=1;817=1;818=1;821=1;822=1;826=1;827=1;828=1;829=1;831=1;832=1;833=1;834=1;835=1;837=1;838=1;840=1;841=1;842=1;843=1;844=1;850=1;851=1;854=1;855=1;856=1;857=1;858=1;859=1;860=1;861=1;862=1;863=1;866=1;867=1;868=1;869=1;870=1;871=1;872=1;874=1;875=1;876=1;878=1;879=1;880=1;883=1;884=1;885=1;886=1;887=1;888=1;889=1;890=1;891=1;892=1;893=1;894=1;896=1;900=1;901=1;902=1;903=1;904=1;906=1;907=1;909=1;911=1;914=1;915=1;916=1;917=1;918=1;919=1;920=1;921=1;924=1;925=1;926=1;927=1;931=1;932=1;935=1;936=1;938=1;940=1;943=1;944=1;946=1;947=1;948=1;950=1;951=1;952=1;954=1;959=1;960=1;961=1;962=1;963=1;964=1;965=1;966=1;967=1;968=1;970=1;973=1;974=1;976=1;978=1;982=1;983=1;984=1;992=1;994=1;1003=1;1004=1;1007=1;1008=1;1009=1;1010=1;1011=1;1012=1;1013=1;1014=1;1015=1;1016=1;1017=1;1018=1;1019=1;1020=14
+
+ncloc_data24
+417=1;19=1;20=1;21=1;22=1;23=1;24=1;25=1;26=1;27=1;28=1;29=1;30=1;31=1;32=1;33=1;34=1;35=1;36=1;37=1;38=1;39=1;40=1;41=1;42=1;43=1;44=1;45=1;46=1;47=1;48=1;49=1;50=1;51=1;52=1;53=1;54=1;55=1;56=1;57=1;58=1;59=1;60=1;61=1;62=1;63=1;64=1;65=1;66=1;67=1;68=1;70=1;71=1;73=1;74=1;75=1;76=1;77=1;78=1;79=1;80=1;81=1;82=1;83=1;84=1;85=1;86=1;87=1;89=1;90=1;91=1;92=1;93=1;94=1;95=1;96=1;97=1;98=1;99=1;100=1;101=1;102=1;105=1;106=1;109=1;110=1;112=1;114=1;116=1;117=1;119=1;121=1;122=1;123=1;124=1;125=1;126=1;127=1;129=1;131=1;132=1;133=1;134=1;135=1;136=1;137=1;139=1;141=1;142=1;143=1;144=1;145=1;146=1;148=1;150=1;151=1;152=1;153=1;154=1;155=1;157=1;159=1;161=1;163=1;165=1;167=1;169=1;171=1;173=1;175=1;177=1;179=1;181=1;183=1;184=1;186=1;188=1;190=1;192=1;194=1;195=1;196=1;197=1;198=1;199=1;200=1;201=1;202=1;203=1;204=1;205=1;207=1;208=1;209=1;210=1;211=1;212=1;213=1;214=1;215=1;216=1;217=1;219=1;220=1;222=1;223=1;224=1;225=1;226=1;227=1;229=1;230=1;231=1;232=1;233=1;234=1;236=1;237=1;238=1;239=1;240=1;241=1;242=1;243=1;244=1;245=1;246=1;247=1;248=1;249=1;250=1;251=1;252=1;254=1;255=1;256=1;258=1;259=1;260=1;261=1;262=1;263=1;264=1;265=1;266=1;267=1;268=1;269=1;270=1;272=1;273=1;274=1;275=1;278=1;279=1;280=1;281=1;282=1;283=1;284=1;285=1;286=1;287=1;288=1;289=1;290=1;291=1;292=1;293=1;294=1;295=1;297=1;298=1;299=1;300=1;301=1;302=1;303=1;304=1;306=1;307=1;308=1;309=1;310=1;311=1;312=1;313=1;319=1;320=1;321=1;322=1;323=1;324=1;325=1;326=1;327=1;328=1;329=1;330=1;331=1;333=1;338=1;339=1;340=1;341=1;346=1;347=1;348=1;349=1;351=1;352=1;353=1;354=1;355=1;356=1;357=1;358=1;359=1;360=1;361=1;362=1;363=1;364=1;365=1;366=1;367=1;368=1;370=1;371=1;372=1;373=1;374=1;375=1;376=1;379=1;380=1;381=1;382=1;383=1;384=1;385=1;386=1;387=1;388=1;389=1;390=1;391=1;392=1;393=1;394=1;395=1;396=1;397=1;398=1;399=1;400=1;401=1;402=1;404=1;405=1;406=1;407=1;408=1;409=1;410=1;411=1;412=1;413=1;414=1;415=1;416=1;417=1;418=1;419=1;420=1;421=1;423=1;424=1;425=1;426=1;427=1;428=1;429=1;430=1;431=1;432=1;433=1;434=1;435=1;436=1;438=1;439=1;440=1;441=1;447=1;448=1;450=1;451=1;452=1;453=1;454=1;455=1;456=1;457=1;458=1;459=1;460=1;461=1;462=1;463=1;464=1;465=1;467=1;468=1;469=1;470=1;471=1;473=1;474=1;475=1;481=1;482=1;483=1;484=1;485=1;486=1;488=1;489=1;490=1;491=1;492=1;493=1;494=1;496=1;497=1;498=1;499=1;500=1;501=1;502=1;504=1;505=1;506=1;507=1;508=1;509=1;510=1;511=1;512=1;513=1;514=1;515=1;516=1;518=1;519=1;520=1;521=1;522=1;523=1;524=1;525=1;526=1;527=1;528=1;530=1;531=1;532=1;533=1;534=1;536=1;537=1;538=1;539=1;540=1;541=1;542=1;543=1;550=1;551=1;552=1;553=1;554=1;556=1;557=1;558=1;559=1;560=1;561=1;562=1;563=1;564=1;565=1;567=1;568=1;569=1;570=1;571=1;572=1;574=1;575=1;576=1;577=1;578=1;579=1;580=1;581=1;582=1;583=1;584=1;585=1;586=1;587=1;588=1;589=1;590=1;591=1;592=1;593=1;594=1;595=1;596=1;597=1;598=1;600=1;601=1;602=1;603=1;604=1;605=1;606=1;607=1;609=1;612=1;613=1;614=1;615=1;616=1;617=1;618=1;619=1;620=1;622=1;623=1;624=1;625=1;626=1;627=1;629=1;630=1;631=1;632=1;633=1;634=1;635=1;636=1;637=1;638=1;639=1;640=1;641=1;642=1;643=1;644=1;645=1;646=1;647=1;648=1;649=1;650=1;651=1;652=1;653=1;654=1;655=1;656=1;657=1;659=1;660=1;661=1;662=1;663=1;664=1;665=1;666=1;667=1;668=1;669=1;670=1;671=1;672=1;673=1;674=1;675=1;676=1;677=1;678=1;679=1;680=1;681=1;682=1;683=1;684=1;685=1;686=1;687=1;688=1;689=1;690=1;691=1;692=1;693=1;694=1;695=1;696=1;697=1;698=1;699=1;700=1;701=1;702=1;703=1;704=1;705=1;706=1;707=1;708=1;709=1;710=1;711=1;712=1;713=1;714=1;715=1;716=1;717=1;718=1;719=1;720=1;721=1;722=1;723=1;724=1;726=1;727=1;728=1;729=1;730=1;731=1;732=1;733=1;734=1;740=1;741=1;742=1;743=1;744=1;745=1;747=1;749=1;752=1;753=1;754=1;755=1;756=1;757=1;758=1;760=1;761=1;762=1;763=1;764=1;765=1;766=1;767=1;768=1;769=1;770=1;771=1;772=1;773=1;774=1;775=1;776=1;777=1;778=1;779=1;780=1;782=1;783=1;784=1;786=1;791=1;792=1;793=1;794=1;795=1;796=1;797=1;798=1;799=1;800=1;801=1;802=1;803=1;804=1;805=1;811=1;812=1;813=1;814=1;816=1;817=1;818=1;820=1;821=1;822=1;823=1;824=1;826=1;827=1;828=1;829=1;831=1;832=1;833=1;834=1;835=1;836=1;837=1;838=1;839=1;840=1;841=1;842=1;843=1;844=1;846=1;850=1;851=1;852=1;854=1;855=1;856=1;857=1;858=1;859=1;860=1;861=1;862=1;863=1;865=1;866=1;867=1;868=1;869=1;870=1;871=1;872=1;873=1;874=1;875=1;876=1;878=1;879=1;880=1;882=1;883=1;884=1;885=1;886=1;887=1;888=1;889=1;890=1;891=1;892=1;893=1;894=1;895=1;896=1;897=1;899=1;900=1;901=1;902=1;903=1;904=1;905=1;906=1;907=1;908=1;909=1;910=1;911=1;912=1;914=1;915=1;916=1;917=1;918=1;919=1;920=1;921=1;922=1;924=1;925=1;926=1;927=1;928=1;930=1;931=1;932=1;933=1;934=1;935=1;936=1;937=1;938=1;939=1;940=1;942=1;943=1;944=1;945=1;946=1;947=1;948=1;949=1;950=1;951=1;952=1;953=1;954=1;958=1;959=1;960=1;961=1;962=1;963=1;964=1;965=1;966=1;967=1;968=1;969=1;970=1;971=1;972=1;973=1;974=1;975=1;976=1;977=1;978=1;979=1;981=1;982=1;983=1;984=1;992=1;993=1;994=1;995=1;997=1;1003=1;1004=1;1005=1;1007=1;1008=1;1009=1;1010=1;1011=1;1012=1;1013=1;1014=1;1015=1;1016=1;1017=1;1018=1;1019=1;1020=1;1021=1;1027=1;1028=1;1029=1;1030=1;1032=1;1033=1;1034=1;1035=1;1036=1;1037=1;1039=1;1040=1;1041=1;1043=1;1044=1;1045=1;1048=1;1049=1;1050=1;1051=1;1052=1;1053=1;1055=1;1056=1;1057=1;1058=1;1060=1;1061=1;1062=1;1063=1;1064=1;1065=1;1066=1;1067=1;1068=1;1069=1;1070=1;1071=1;1072=1;1073=1;1074=1;1075=1;1076=1;1077=1;1078=1;1079=1;1082=1;1083=1;1084=1;1085=1;1086=1;1087=1;1088=1;1090=1;1091=1;1092=1;1093=1;1094=1;1095=1;1097=1;1098=1;1099=1;1100=1;1101=1;1102=1;1103=1;1104=1;1105=1;1107=1;1108=1;1109=1;1111=1;1112=1;1113=1;1114=1;1115=1;1116=1;1117=1;1118=1;1119=1;1120=1;1121=1;1122=1;1123=1;1125=1;1126=1;1127=1;1128=1;1130=1;1132=1;1133=1;1135=1;1137=1;1139=1;1141=1;1143=1;1144=1;1145=1;1146=1;1147=1;1148=1;1149=1;1150=1;1151=1;1152=1;1153=1;1154=1;1156=1;1157=1;1158=1;1159=1;1160=1;1161=1;1162=1;1163=1;1164=1;1165=1;1166=1;1167=1;1168=1;1170=1;1171=1;1172=1;1173=1;1174=1;1175=1;1176=1;1177=1;1178=1;1179=1;1180=1;1181=1;1182=1;1183=1;1184=1;1185=1;1187=1;1189=1;1190=1;1191=1;1192=1;1193=1;1194=1;1195=1;1196=1;1197=1;1198=1;1200=1;1202=1;1203=1;1204=1;1205=1;1206=1;1207=1;1208=1;1209=1;1210=1;1211=1;1213=1;1215=1;1216=1;1218=1;1219=1;1221=1;1222=1;1223=1;1224=1;1225=1;1226=1;1227=1;1228=1;1229=1;1230=1;1231=1;1232=1;1233=1;1234=1;1235=1;1236=1;1237=1;1239=1;1240=1;1241=1;1242=1;1244=1;1245=1;1246=1;1247=1;1248=1;1249=1;1250=1;1251=1;1253=1;1254=1;1255=1;1256=1;1258=1;1260=1;1262=1;1264=1;1265=1;1266=1;1267=1;1268=1;1269=1;1270=1;1271=1;1273=1;1274=1;1275=1;1276=1;1278=1;1279=1;1280=1;1281=1;1282=1;1284=1;1286=1;1288=1;1289=1;1290=1;1292=1;1293=1;1294=1;1295=1;1296=1;1297=1;1298=1;1299=1;1301=1;1302=1;1303=1;1304=1;1305=1;1306=1;1307=1;1309=1;1310=1;1311=1;1312=1;1313=1
\ No newline at end of file
diff --git a/src/src/build/sonar/scanner-report/measures-38.pb b/src/src/build/sonar/scanner-report/measures-38.pb
new file mode 100644
index 0000000..da3ea57
--- /dev/null
+++ b/src/src/build/sonar/scanner-report/measures-38.pb
@@ -0,0 +1,15 @@
+
+classes
+ functions
+
+complexity
+
comment_lines
+
+statementsG
+ncloc
+cognitive_complexity!
+executable_lines_data2
+128=1;129=1;130=1;131=1;134=1;135=1;140=1;145=1;146=1;147=1;148=1;149=1;150=1;153=1;156=1;157=1;158=1;159=1;160=1;161=1;163=1;169=1;174=1;175=1;176=1;49=1;178=1;51=1;52=1;53=1;181=1;182=1;186=1;187=1;188=1;190=1;191=1;193=1;194=1;195=1;196=1;197=1;198=1;201=1;203=1;204=1;207=1;208=1;81=1;82=1;83=1;211=1;212=1;86=1;87=1;217=1;90=1;218=1;91=1;94=1;95=1;98=1;100=1;104=1;105=1;107=1;108=1;109=1;110=1;111=1;112=1;114=1;115=1;116=1;117=1;123=1
+
+ncloc_data2
+17=1;19=1;20=1;21=1;22=1;23=1;24=1;25=1;26=1;27=1;28=1;29=1;30=1;31=1;32=1;33=1;35=1;37=1;38=1;40=1;41=1;42=1;43=1;45=1;46=1;47=1;49=1;50=1;51=1;52=1;53=1;54=1;59=1;64=1;70=1;75=1;76=1;78=1;80=1;81=1;82=1;83=1;85=1;86=1;87=1;89=1;90=1;91=1;93=1;94=1;95=1;97=1;98=1;100=1;102=1;103=1;104=1;105=1;107=1;108=1;109=1;110=1;111=1;112=1;114=1;115=1;116=1;117=1;118=1;119=1;120=1;121=1;123=1;124=1;126=1;127=1;128=1;129=1;130=1;131=1;132=1;133=1;134=1;135=1;136=1;137=1;138=1;139=1;140=1;141=1;143=1;144=1;145=1;146=1;147=1;148=1;149=1;150=1;151=1;152=1;153=1;154=1;155=1;156=1;157=1;158=1;159=1;160=1;161=1;162=1;163=1;164=1;165=1;166=1;167=1;168=1;169=1;170=1;172=1;173=1;174=1;175=1;176=1;177=1;178=1;179=1;180=1;181=1;182=1;184=1;185=1;186=1;187=1;188=1;190=1;191=1;193=1;194=1;195=1;196=1;197=1;198=1;199=1;200=1;201=1;203=1;204=1;205=1;207=1;208=1;209=1;211=1;212=1;213=1;214=1;215=1;216=1;217=1;218=1;219=1;220=1
\ No newline at end of file
diff --git a/src/src/build/sonar/scanner-report/measures-39.pb b/src/src/build/sonar/scanner-report/measures-39.pb
new file mode 100644
index 0000000..fae668c
--- /dev/null
+++ b/src/src/build/sonar/scanner-report/measures-39.pb
@@ -0,0 +1,15 @@
+
+classes
+ functions
+
+complexity)
+
comment_lines
+
+statements?
+ncloc
+cognitive_complexity
+executable_lines_data2
+129=1;130=1;131=1;132=1;133=1;134=1;135=1;137=1;140=1;141=1;145=1;148=1;151=1;155=1;31=1;159=1;32=1;33=1;34=1;35=1;163=1;36=1;37=1;38=1;39=1;167=1;40=1;41=1;42=1;43=1;171=1;44=1;45=1;175=1;179=1;183=1;187=1;191=1;195=1;199=1;203=1;207=1;211=1;87=1;215=1;88=1;89=1;90=1;91=1;219=1;92=1;93=1;94=1;95=1;223=1;96=1;97=1;98=1;99=1;227=1;100=1;101=1;102=1;231=1;104=1;105=1;106=1;107=1;235=1;108=1;109=1;110=1;239=1;115=1;116=1;119=1;120=1;123=1;124=1;125=1;126=1;127=1
+
+ncloc_data2
+17=1;19=1;20=1;21=1;23=1;24=1;25=1;26=1;27=1;30=1;31=1;32=1;33=1;34=1;35=1;36=1;37=1;38=1;39=1;40=1;41=1;42=1;43=1;44=1;45=1;46=1;48=1;49=1;50=1;51=1;52=1;53=1;54=1;55=1;56=1;57=1;58=1;59=1;60=1;61=1;63=1;64=1;65=1;66=1;67=1;68=1;69=1;70=1;71=1;72=1;73=1;74=1;75=1;76=1;77=1;78=1;80=1;81=1;82=1;83=1;84=1;86=1;87=1;88=1;89=1;90=1;91=1;92=1;93=1;94=1;95=1;96=1;97=1;98=1;99=1;100=1;101=1;102=1;104=1;105=1;106=1;107=1;108=1;109=1;110=1;111=1;112=1;113=1;115=1;116=1;117=1;119=1;120=1;122=1;123=1;124=1;125=1;126=1;127=1;129=1;130=1;131=1;132=1;133=1;134=1;135=1;136=1;137=1;138=1;139=1;140=1;141=1;142=1;143=1;144=1;145=1;147=1;148=1;149=1;150=1;151=1;152=1;154=1;155=1;156=1;158=1;159=1;160=1;162=1;163=1;164=1;166=1;167=1;168=1;170=1;171=1;172=1;174=1;175=1;176=1;178=1;179=1;180=1;182=1;183=1;184=1;186=1;187=1;188=1;190=1;191=1;192=1;194=1;195=1;196=1;198=1;199=1;200=1;202=1;203=1;204=1;206=1;207=1;208=1;210=1;211=1;212=1;214=1;215=1;216=1;218=1;219=1;220=1;222=1;223=1;224=1;226=1;227=1;228=1;230=1;231=1;232=1;234=1;235=1;236=1;238=1;239=1;240=1;241=1;242=1
\ No newline at end of file
diff --git a/src/src/build/sonar/scanner-report/measures-4.pb b/src/src/build/sonar/scanner-report/measures-4.pb
new file mode 100644
index 0000000..c2de6d7
Binary files /dev/null and b/src/src/build/sonar/scanner-report/measures-4.pb differ
diff --git a/src/src/build/sonar/scanner-report/measures-40.pb b/src/src/build/sonar/scanner-report/measures-40.pb
new file mode 100644
index 0000000..474de4f
--- /dev/null
+++ b/src/src/build/sonar/scanner-report/measures-40.pb
@@ -0,0 +1,15 @@
+
+classes
+ functions6
+
+complexity
+
comment_lines
+
+statements
+ncloc
+cognitive_complexity
+executable_lines_data2
+1024=1;1027=1;1028=1;1031=1;1032=1;1033=1;1034=1;1036=1;1039=1;1043=1;1044=1;1047=1;1048=1;1051=1;1052=1;1057=1;1061=1;1062=1;1063=1;1066=1;1067=1;1070=1;1071=1;1072=1;1073=1;1078=1;1079=1;1080=1;1081=1;1083=1;1084=1;1085=1;1087=1;1088=1;1089=1;1090=1;1093=1;1094=1;1098=1;1103=1;1104=1;1105=1;1106=1;1107=1;1108=1;1109=1;1110=1;1111=1;1112=1;1113=1;1114=1;1115=1;1116=1;1117=1;1118=1;1119=1;1120=1;1121=1;1122=1;1123=1;1124=1;1125=1;1126=1;1127=1;1129=1;1132=1;1135=1;115=1;1139=1;1140=1;1141=1;1142=1;1148=1;1149=1;1150=1;1151=1;1152=1;1153=1;1154=1;1159=1;1160=1;1161=1;1162=1;1163=1;1164=1;1165=1;1168=1;1171=1;1172=1;1173=1;150=1;1174=1;152=1;1176=1;153=1;154=1;155=1;1183=1;1187=1;1189=1;166=1;1192=1;169=1;1193=1;170=1;1194=1;171=1;1195=1;1196=1;1197=1;1199=1;176=1;1200=1;177=1;1202=1;1203=1;1204=1;181=1;182=1;1206=1;183=1;1207=1;1208=1;1209=1;1210=1;187=1;189=1;1213=1;190=1;191=1;192=1;1216=1;194=1;1218=1;1221=1;198=1;1222=1;199=1;200=1;1225=1;202=1;203=1;1228=1;206=1;1231=1;1232=1;209=1;210=1;1234=1;211=1;1236=1;215=1;1239=1;216=1;217=1;1242=1;219=1;1244=1;221=1;1245=1;222=1;1246=1;224=1;1248=1;1249=1;226=1;1250=1;1251=1;1252=1;1253=1;1254=1;1255=1;1256=1;234=1;1258=1;235=1;1259=1;237=1;238=1;1262=1;1263=1;240=1;1264=1;241=1;1265=1;1266=1;1267=1;244=1;245=1;1269=1;246=1;247=1;1271=1;248=1;1272=1;250=1;251=1;1275=1;253=1;256=1;258=1;259=1;260=1;261=1;263=1;265=1;266=1;267=1;268=1;269=1;270=1;272=1;276=1;280=1;281=1;282=1;283=1;284=1;285=1;286=1;287=1;288=1;291=1;294=1;295=1;296=1;297=1;298=1;299=1;300=1;301=1;302=1;303=1;304=1;306=1;307=1;308=1;309=1;310=1;319=1;321=1;323=1;325=1;326=1;328=1;329=1;331=1;332=1;334=1;335=1;337=1;338=1;342=1;344=1;345=1;346=1;352=1;356=1;359=1;364=1;369=1;372=1;373=1;374=1;375=1;376=1;377=1;378=1;379=1;380=1;381=1;382=1;383=1;384=1;385=1;386=1;388=1;389=1;391=1;392=1;393=1;394=1;396=1;405=1;407=1;408=1;409=1;410=1;411=1;413=1;414=1;416=1;417=1;418=1;419=1;421=1;422=1;423=1;424=1;425=1;426=1;427=1;429=1;430=1;431=1;435=1;439=1;441=1;442=1;443=1;444=1;445=1;446=1;447=1;449=1;450=1;453=1;457=1;462=1;466=1;467=1;468=1;469=1;472=1;473=1;477=1;478=1;479=1;482=1;483=1;484=1;485=1;488=1;489=1;490=1;491=1;492=1;493=1;494=1;495=1;496=1;497=1;500=1;501=1;502=1;504=1;505=1;508=1;511=1;512=1;515=1;517=1;521=1;522=1;524=1;525=1;527=1;528=1;530=1;531=1;532=1;534=1;536=1;537=1;539=1;541=1;542=1;548=1;549=1;550=1;551=1;552=1;553=1;554=1;558=1;559=1;560=1;571=1;572=1;573=1;579=1;580=1;581=1;582=1;583=1;584=1;585=1;590=1;591=1;592=1;593=1;594=1;599=1;600=1;601=1;602=1;607=1;613=1;614=1;615=1;616=1;617=1;618=1;619=1;629=1;630=1;635=1;636=1;637=1;639=1;640=1;641=1;643=1;649=1;653=1;654=1;655=1;656=1;659=1;660=1;661=1;662=1;663=1;664=1;665=1;666=1;667=1;668=1;670=1;671=1;674=1;675=1;676=1;677=1;678=1;679=1;682=1;684=1;685=1;687=1;690=1;695=1;696=1;697=1;700=1;705=1;706=1;707=1;708=1;709=1;711=1;713=1;714=1;716=1;719=1;720=1;724=1;725=1;726=1;727=1;728=1;730=1;733=1;735=1;736=1;737=1;738=1;739=1;741=1;743=1;748=1;749=1;750=1;751=1;752=1;755=1;756=1;757=1;758=1;759=1;761=1;763=1;764=1;766=1;767=1;769=1;770=1;775=1;776=1;778=1;783=1;786=1;787=1;788=1;790=1;793=1;794=1;795=1;798=1;799=1;800=1;801=1;802=1;803=1;804=1;805=1;806=1;808=1;812=1;813=1;816=1;817=1;819=1;820=1;823=1;824=1;825=1;827=1;828=1;829=1;830=1;831=1;832=1;835=1;836=1;837=1;838=1;839=1;840=1;841=1;842=1;843=1;846=1;847=1;848=1;849=1;850=1;852=1;853=1;856=1;857=1;862=1;866=1;869=1;870=1;872=1;874=1;879=1;881=1;885=1;886=1;887=1;888=1;889=1;890=1;892=1;893=1;894=1;895=1;896=1;897=1;899=1;900=1;905=1;908=1;909=1;910=1;911=1;912=1;914=1;918=1;919=1;922=1;923=1;924=1;926=1;928=1;929=1;930=1;931=1;932=1;934=1;939=1;940=1;942=1;943=1;947=1;948=1;949=1;951=1;952=1;953=1;955=1;956=1;957=1;958=1;959=1;960=1;961=1;963=1;964=1;966=1;967=1;969=1;970=1;976=1;981=1;983=1;984=1;986=1;987=1;988=1;989=1;991=1;992=1;994=1;995=1;996=1;997=1;999=1;1002=1;1007=1;1008=1;1009=1;1010=1;1013=1;1014=1;1015=1;1016=1;1019=1;1020=1;1023=13
+
+ncloc_data23
+317=1;19=1;20=1;21=1;22=1;23=1;24=1;25=1;26=1;27=1;28=1;29=1;30=1;31=1;32=1;33=1;34=1;35=1;36=1;37=1;38=1;39=1;40=1;41=1;42=1;43=1;44=1;45=1;46=1;47=1;48=1;49=1;50=1;51=1;52=1;53=1;54=1;55=1;56=1;57=1;58=1;59=1;60=1;61=1;62=1;63=1;64=1;65=1;66=1;67=1;68=1;69=1;70=1;71=1;72=1;74=1;76=1;77=1;78=1;79=1;80=1;81=1;82=1;83=1;84=1;85=1;86=1;87=1;88=1;90=1;91=1;92=1;93=1;94=1;95=1;97=1;99=1;101=1;103=1;105=1;107=1;109=1;112=1;113=1;114=1;115=1;120=1;122=1;124=1;126=1;128=1;130=1;132=1;134=1;136=1;138=1;140=1;142=1;144=1;146=1;148=1;150=1;152=1;153=1;154=1;155=1;157=1;158=1;160=1;161=1;162=1;163=1;164=1;165=1;166=1;167=1;168=1;169=1;170=1;171=1;176=1;177=1;179=1;180=1;181=1;182=1;183=1;185=1;187=1;189=1;190=1;191=1;192=1;193=1;194=1;195=1;196=1;197=1;198=1;199=1;200=1;201=1;202=1;203=1;204=1;205=1;206=1;207=1;208=1;209=1;210=1;211=1;213=1;214=1;215=1;216=1;217=1;219=1;220=1;221=1;222=1;223=1;224=1;225=1;226=1;231=1;232=1;234=1;235=1;237=1;238=1;239=1;240=1;241=1;244=1;245=1;246=1;247=1;248=1;250=1;251=1;253=1;254=1;255=1;256=1;257=1;258=1;259=1;260=1;261=1;262=1;263=1;265=1;266=1;267=1;268=1;269=1;270=1;271=1;272=1;273=1;274=1;275=1;276=1;278=1;279=1;280=1;281=1;282=1;283=1;284=1;285=1;286=1;287=1;288=1;289=1;290=1;291=1;292=1;293=1;294=1;295=1;296=1;297=1;298=1;299=1;300=1;301=1;302=1;303=1;304=1;306=1;307=1;308=1;309=1;310=1;313=1;314=1;315=1;316=1;319=1;321=1;323=1;325=1;326=1;327=1;328=1;329=1;330=1;331=1;332=1;333=1;334=1;335=1;336=1;337=1;338=1;339=1;340=1;341=1;342=1;343=1;344=1;345=1;346=1;347=1;348=1;350=1;352=1;353=1;354=1;356=1;357=1;359=1;360=1;361=1;362=1;364=1;365=1;366=1;369=1;370=1;371=1;372=1;373=1;374=1;375=1;376=1;377=1;378=1;379=1;380=1;381=1;382=1;383=1;384=1;385=1;386=1;387=1;388=1;389=1;390=1;391=1;392=1;393=1;394=1;395=1;396=1;397=1;398=1;399=1;400=1;401=1;402=1;404=1;405=1;407=1;408=1;409=1;410=1;411=1;412=1;413=1;414=1;415=1;416=1;417=1;418=1;419=1;421=1;422=1;423=1;424=1;425=1;426=1;427=1;428=1;429=1;430=1;431=1;432=1;434=1;435=1;436=1;438=1;439=1;441=1;442=1;443=1;444=1;445=1;446=1;447=1;448=1;449=1;450=1;451=1;452=1;453=1;455=1;457=1;458=1;460=1;462=1;463=1;465=1;466=1;467=1;468=1;469=1;471=1;472=1;473=1;475=1;476=1;477=1;478=1;479=1;481=1;482=1;483=1;484=1;485=1;486=1;488=1;489=1;490=1;491=1;492=1;493=1;494=1;495=1;496=1;497=1;498=1;499=1;500=1;501=1;502=1;503=1;504=1;505=1;506=1;507=1;508=1;509=1;510=1;511=1;512=1;513=1;514=1;515=1;516=1;517=1;518=1;519=1;520=1;521=1;522=1;523=1;524=1;525=1;526=1;527=1;528=1;530=1;531=1;532=1;534=1;536=1;537=1;538=1;539=1;540=1;541=1;542=1;543=1;546=1;547=1;548=1;549=1;550=1;551=1;552=1;553=1;554=1;558=1;559=1;560=1;561=1;571=1;572=1;573=1;579=1;580=1;581=1;582=1;583=1;584=1;585=1;586=1;587=1;588=1;589=1;590=1;591=1;592=1;593=1;594=1;595=1;596=1;597=1;598=1;599=1;600=1;601=1;602=1;603=1;604=1;605=1;606=1;607=1;608=1;610=1;612=1;613=1;614=1;615=1;616=1;617=1;618=1;619=1;624=1;627=1;629=1;630=1;633=1;634=1;635=1;636=1;637=1;638=1;639=1;640=1;641=1;642=1;643=1;644=1;645=1;646=1;647=1;648=1;649=1;650=1;652=1;653=1;654=1;655=1;656=1;658=1;659=1;660=1;661=1;662=1;663=1;664=1;665=1;666=1;667=1;668=1;669=1;670=1;671=1;673=1;674=1;675=1;676=1;677=1;678=1;679=1;681=1;682=1;683=1;684=1;685=1;687=1;688=1;689=1;690=1;691=1;692=1;695=1;696=1;697=1;698=1;699=1;700=1;701=1;703=1;704=1;705=1;706=1;707=1;708=1;709=1;710=1;711=1;712=1;713=1;714=1;715=1;716=1;718=1;719=1;720=1;721=1;722=1;724=1;725=1;726=1;727=1;728=1;730=1;731=1;733=1;734=1;735=1;736=1;737=1;738=1;739=1;740=1;741=1;742=1;743=1;747=1;748=1;749=1;750=1;751=1;752=1;754=1;755=1;756=1;757=1;758=1;759=1;760=1;761=1;762=1;763=1;764=1;765=1;766=1;767=1;768=1;769=1;770=1;774=1;775=1;776=1;778=1;779=1;780=1;781=1;782=1;783=1;785=1;786=1;787=1;788=1;789=1;790=1;792=1;793=1;794=1;795=1;797=1;798=1;799=1;800=1;801=1;802=1;803=1;804=1;805=1;806=1;807=1;808=1;809=1;810=1;811=1;812=1;813=1;814=1;816=1;817=1;818=1;819=1;820=1;821=1;823=1;824=1;825=1;826=1;827=1;828=1;829=1;830=1;831=1;832=1;833=1;834=1;835=1;836=1;837=1;838=1;839=1;840=1;841=1;842=1;843=1;844=1;845=1;846=1;847=1;848=1;849=1;850=1;851=1;852=1;853=1;854=1;856=1;857=1;858=1;862=1;863=1;866=1;868=1;869=1;870=1;871=1;872=1;873=1;874=1;876=1;879=1;880=1;881=1;883=1;884=1;885=1;886=1;887=1;888=1;889=1;890=1;891=1;892=1;893=1;894=1;895=1;896=1;897=1;898=1;899=1;900=1;901=1;902=1;903=1;904=1;905=1;907=1;908=1;909=1;910=1;911=1;912=1;913=1;914=1;915=1;916=1;918=1;919=1;920=1;922=1;923=1;924=1;926=1;927=1;928=1;929=1;930=1;931=1;932=1;933=1;934=1;935=1;937=1;938=1;939=1;940=1;941=1;942=1;943=1;945=1;946=1;947=1;948=1;949=1;950=1;951=1;952=1;953=1;954=1;955=1;956=1;957=1;958=1;959=1;960=1;961=1;962=1;963=1;964=1;965=1;966=1;967=1;968=1;969=1;970=1;971=1;972=1;973=1;974=1;976=1;977=1;979=1;980=1;981=1;983=1;984=1;986=1;987=1;988=1;989=1;990=1;991=1;992=1;993=1;994=1;995=1;996=1;997=1;998=1;999=1;1000=1;1002=1;1003=1;1005=1;1006=1;1007=1;1008=1;1009=1;1010=1;1011=1;1012=1;1013=1;1014=1;1015=1;1016=1;1017=1;1018=1;1019=1;1020=1;1021=1;1022=1;1023=1;1024=1;1025=1;1026=1;1027=1;1028=1;1029=1;1030=1;1031=1;1032=1;1033=1;1034=1;1035=1;1036=1;1037=1;1038=1;1039=1;1040=1;1041=1;1042=1;1043=1;1044=1;1045=1;1046=1;1047=1;1048=1;1049=1;1050=1;1051=1;1052=1;1053=1;1054=1;1055=1;1056=1;1057=1;1058=1;1060=1;1061=1;1062=1;1063=1;1064=1;1065=1;1066=1;1067=1;1068=1;1069=1;1070=1;1071=1;1072=1;1073=1;1074=1;1075=1;1078=1;1079=1;1080=1;1081=1;1082=1;1083=1;1084=1;1085=1;1086=1;1087=1;1088=1;1089=1;1090=1;1092=1;1093=1;1094=1;1096=1;1097=1;1098=1;1099=1;1101=1;1102=1;1103=1;1104=1;1105=1;1106=1;1107=1;1108=1;1109=1;1110=1;1111=1;1112=1;1113=1;1114=1;1115=1;1116=1;1117=1;1118=1;1119=1;1120=1;1121=1;1122=1;1123=1;1124=1;1125=1;1126=1;1127=1;1128=1;1129=1;1131=1;1132=1;1134=1;1135=1;1136=1;1138=1;1139=1;1140=1;1141=1;1142=1;1144=1;1147=1;1148=1;1149=1;1150=1;1151=1;1152=1;1153=1;1154=1;1155=1;1156=1;1157=1;1159=1;1160=1;1161=1;1162=1;1163=1;1164=1;1165=1;1167=1;1168=1;1169=1;1170=1;1171=1;1172=1;1173=1;1174=1;1175=1;1176=1;1177=1;1178=1;1179=1;1180=1;1181=1;1182=1;1183=1;1185=1;1186=1;1187=1;1188=1;1189=1;1190=1;1191=1;1192=1;1193=1;1194=1;1195=1;1196=1;1197=1;1198=1;1199=1;1200=1;1201=1;1202=1;1203=1;1204=1;1205=1;1206=1;1207=1;1208=1;1209=1;1210=1;1211=1;1212=1;1213=1;1214=1;1215=1;1216=1;1218=1;1220=1;1221=1;1222=1;1223=1;1225=1;1226=1;1228=1;1230=1;1231=1;1232=1;1233=1;1234=1;1235=1;1236=1;1237=1;1239=1;1240=1;1241=1;1242=1;1243=1;1244=1;1245=1;1246=1;1248=1;1249=1;1250=1;1251=1;1252=1;1253=1;1254=1;1255=1;1256=1;1257=1;1258=1;1259=1;1261=1;1262=1;1263=1;1264=1;1265=1;1266=1;1267=1;1268=1;1269=1;1270=1;1271=1;1272=1;1273=1;1274=1;1275=1;1276=1;1278=1;1279=1
\ No newline at end of file
diff --git a/src/src/build/sonar/scanner-report/measures-41.pb b/src/src/build/sonar/scanner-report/measures-41.pb
new file mode 100644
index 0000000..91f5ba5
--- /dev/null
+++ b/src/src/build/sonar/scanner-report/measures-41.pb
@@ -0,0 +1,15 @@
+
+classes
+ functions
+
+complexity%
+
comment_lines#
+
+statementsO
+ncloc
+cognitive_complexity)
+executable_lines_data2
+129=1;130=1;131=1;132=1;133=1;134=1;135=1;136=1;137=1;138=1;143=1;144=1;147=1;148=1;152=1;153=1;154=1;156=1;157=1;158=1;159=1;160=1;162=1;163=1;167=1;168=1;44=1;172=1;45=1;173=1;46=1;47=1;175=1;48=1;50=1;51=1;52=1;180=1;181=1;182=1;55=1;56=1;58=1;186=1;59=1;187=1;188=1;191=1;192=1;193=1;194=1;67=1;195=1;68=1;196=1;69=1;70=1;71=1;199=1;202=1;75=1;203=1;80=1;81=1;82=1;83=1;85=1;88=1;89=1;90=1;93=1;97=1;98=1;99=1;102=1;103=1;104=1;105=1;106=1;109=1;110=1;113=1;114=1;115=1;116=1;117=1;118=1;120=1;123=1;125=1
+
+ncloc_data2
+17=1;19=1;20=1;21=1;22=1;23=1;24=1;26=1;28=1;29=1;30=1;31=1;34=1;35=1;36=1;37=1;39=1;41=1;43=1;44=1;45=1;46=1;47=1;48=1;50=1;51=1;52=1;53=1;54=1;55=1;56=1;57=1;58=1;59=1;60=1;61=1;62=1;63=1;64=1;66=1;67=1;68=1;69=1;70=1;71=1;73=1;74=1;75=1;76=1;78=1;79=1;80=1;81=1;82=1;83=1;84=1;85=1;87=1;88=1;89=1;90=1;92=1;93=1;94=1;96=1;97=1;98=1;99=1;101=1;102=1;103=1;104=1;105=1;106=1;107=1;108=1;109=1;110=1;112=1;113=1;114=1;115=1;116=1;117=1;118=1;119=1;120=1;121=1;122=1;123=1;125=1;126=1;128=1;129=1;130=1;131=1;132=1;133=1;134=1;135=1;136=1;137=1;138=1;142=1;143=1;144=1;145=1;146=1;147=1;148=1;149=1;151=1;152=1;153=1;154=1;155=1;156=1;157=1;158=1;159=1;160=1;161=1;162=1;163=1;164=1;166=1;167=1;168=1;169=1;171=1;172=1;173=1;174=1;175=1;176=1;178=1;179=1;180=1;181=1;182=1;184=1;185=1;186=1;187=1;188=1;190=1;191=1;192=1;193=1;194=1;195=1;196=1;197=1;198=1;199=1;200=1;201=1;202=1;203=1;204=1;205=1
\ No newline at end of file
diff --git a/src/src/build/sonar/scanner-report/measures-43.pb b/src/src/build/sonar/scanner-report/measures-43.pb
new file mode 100644
index 0000000..78d0ed2
--- /dev/null
+++ b/src/src/build/sonar/scanner-report/measures-43.pb
@@ -0,0 +1,15 @@
+
+classes
+ functions
+
+complexity0
+
comment_lines`
+
+statements
+ncloc
+cognitive_complexity4
+executable_lines_data2
+256=1;257=1;258=1;259=1;261=1;262=1;263=1;265=1;268=1;270=1;271=1;272=1;273=1;274=1;275=1;276=1;278=1;279=1;280=1;281=1;283=1;285=1;286=1;287=1;288=1;289=1;291=1;293=1;294=1;297=1;298=1;302=1;303=1;304=1;305=1;306=1;308=1;310=1;313=1;316=1;318=1;319=1;320=1;321=1;322=1;325=1;326=1;327=1;329=1;332=1;333=1;334=1;335=1;337=1;338=1;84=1;340=1;87=1;343=1;89=1;345=1;90=1;346=1;91=1;347=1;92=1;348=1;93=1;349=1;94=1;351=1;96=1;97=1;98=1;354=1;99=1;355=1;356=1;103=1;360=1;361=1;362=1;107=1;363=1;108=1;364=1;109=1;365=1;110=1;111=1;112=1;368=1;113=1;369=1;114=1;370=1;117=1;118=1;119=1;377=1;122=1;378=1;379=1;380=1;381=1;126=1;127=1;384=1;131=1;132=1;388=1;389=1;134=1;390=1;135=1;391=1;392=1;393=1;138=1;395=1;140=1;141=1;142=1;143=1;144=1;146=1;147=1;149=1;153=1;156=1;157=1;160=1;164=1;165=1;168=1;169=1;172=1;173=1;174=1;176=1;177=1;180=1;181=1;183=1;184=1;187=1;190=1;191=1;192=1;194=1;195=1;196=1;197=1;198=1;199=1;201=1;204=1;207=1;208=1;209=1;212=1;214=1;215=1;216=1;217=1;218=1;220=1;221=1;223=1;224=1;226=1;227=1;229=1;230=1;231=1;232=1;233=1;234=1;235=1;236=1;238=1;239=1;240=1;241=1;243=1;244=1;245=1;246=1;250=1;251=1;253=1;254=1
+
+ncloc_data2
+17=1;19=1;20=1;21=1;22=1;23=1;24=1;25=1;26=1;27=1;28=1;29=1;30=1;31=1;32=1;33=1;34=1;35=1;36=1;37=1;38=1;39=1;40=1;41=1;42=1;43=1;44=1;45=1;46=1;47=1;48=1;50=1;51=1;52=1;53=1;54=1;56=1;61=1;62=1;64=1;66=1;68=1;70=1;72=1;74=1;76=1;78=1;80=1;82=1;83=1;84=1;87=1;89=1;90=1;91=1;92=1;93=1;94=1;96=1;97=1;98=1;99=1;101=1;102=1;103=1;107=1;108=1;109=1;110=1;111=1;112=1;113=1;114=1;115=1;116=1;117=1;118=1;119=1;120=1;121=1;122=1;123=1;124=1;126=1;127=1;129=1;130=1;131=1;132=1;133=1;134=1;135=1;137=1;138=1;140=1;141=1;142=1;143=1;144=1;145=1;146=1;147=1;149=1;150=1;153=1;154=1;155=1;156=1;157=1;158=1;159=1;160=1;161=1;162=1;164=1;165=1;167=1;168=1;169=1;172=1;173=1;174=1;175=1;176=1;177=1;178=1;179=1;180=1;181=1;182=1;183=1;184=1;185=1;186=1;187=1;190=1;191=1;192=1;193=1;194=1;195=1;196=1;197=1;198=1;199=1;200=1;201=1;202=1;203=1;204=1;206=1;207=1;208=1;209=1;211=1;212=1;214=1;215=1;216=1;217=1;218=1;220=1;221=1;223=1;224=1;226=1;227=1;229=1;230=1;231=1;232=1;233=1;234=1;235=1;236=1;237=1;238=1;239=1;240=1;241=1;242=1;243=1;244=1;245=1;246=1;247=1;248=1;250=1;251=1;253=1;254=1;255=1;256=1;257=1;258=1;259=1;260=1;261=1;262=1;263=1;264=1;265=1;267=1;268=1;270=1;271=1;272=1;273=1;274=1;275=1;276=1;278=1;279=1;280=1;281=1;282=1;283=1;284=1;285=1;286=1;287=1;288=1;289=1;290=1;291=1;292=1;293=1;294=1;296=1;297=1;298=1;299=1;301=1;302=1;303=1;304=1;305=1;306=1;307=1;308=1;309=1;310=1;313=1;316=1;317=1;318=1;319=1;320=1;321=1;322=1;323=1;325=1;326=1;327=1;328=1;329=1;331=1;332=1;333=1;334=1;335=1;336=1;337=1;338=1;339=1;340=1;343=1;344=1;345=1;346=1;347=1;348=1;349=1;350=1;351=1;353=1;354=1;355=1;356=1;357=1;359=1;360=1;361=1;362=1;363=1;364=1;365=1;367=1;368=1;369=1;370=1;371=1;373=1;375=1;376=1;377=1;378=1;379=1;380=1;381=1;382=1;384=1;385=1;387=1;388=1;389=1;390=1;391=1;392=1;393=1;394=1;395=1;396=1;397=1;398=1;399=1
\ No newline at end of file
diff --git a/src/src/build/sonar/scanner-report/measures-45.pb b/src/src/build/sonar/scanner-report/measures-45.pb
new file mode 100644
index 0000000..3632e38
Binary files /dev/null and b/src/src/build/sonar/scanner-report/measures-45.pb differ
diff --git a/src/src/build/sonar/scanner-report/measures-46.pb b/src/src/build/sonar/scanner-report/measures-46.pb
new file mode 100644
index 0000000..a0bbca3
Binary files /dev/null and b/src/src/build/sonar/scanner-report/measures-46.pb differ
diff --git a/src/src/build/sonar/scanner-report/measures-6.pb b/src/src/build/sonar/scanner-report/measures-6.pb
new file mode 100644
index 0000000..da48b01
--- /dev/null
+++ b/src/src/build/sonar/scanner-report/measures-6.pb
@@ -0,0 +1,17 @@
+
+classes
+ functions
+
+complexity
+
comment_lines
+
+statements[
+ncloc
+cognitive_complexity
+
+
+executable_lines_data2
+ 38=1;40=1;48=1;49=1;50=1;51=1;52=1;53=1;54=1;55=1;56=1;57=1;58=1;59=1;60=1;61=1;62=1;63=1;64=1;65=1;66=1;67=1;68=1;71=1;72=1;73=1;74=1;75=1;76=1;77=1;78=1;79=1;80=1;81=1;82=1;83=1;86=1;87=1;93=1;94=1;95=1;96=1;97=1;98=1;99=1;105=1;106=1;107=1;108=1;109=1;110=1;111=1;112=1;118=1;119=1;120=1;121=1;122=1;123=1;124=1;130=1;131=1;132=1;133=1;134=1;135=1;136=1;137=1;143=1;144=1;145=1;146=1;147=1;148=1;149=1;150=1;156=1;157=1;158=1;159=1;160=1;161=1;162=1;163=1;169=1;170=1;171=1;172=1;173=1;174=1;175=1;176=1;182=1;183=1;184=1;185=1;186=1;187=1;193=1;194=1;195=1;196=1;197=1;198=1;204=1;205=1;206=1;207=1;208=1;209=1;210=1;211=1;214=1;215=1;218=1;219=1;220=1;221=1;222=1;225=1;226=1;227=1;228=1;229=1;230=1;231=1;233=1;234=1;235=1;236=1;237=1;238=1;239=1;240=1;243=1;244=1;245=1;247=1;248=1;249=1;251=1;254=1;255=1;256=1;258=1;259=1;261=1;266=1;267=1;268=1;273=1;274=1;275=1;276=1;281=1;282=1;283=1;284=1;289=1;290=1;291=1;292=1;293=1;296=1;297=1;298=1;299=1;300=1;303=1;304=1;305=1;307=1;308=1;309=1;310=1;313=1;314=1;316=1;321=1;322=1;323=1;327=1;328=1;330=1;331=1;332=1;333=1;336=1;337=1;338=1;339=1;342=1;343=1;344=1;347=1;348=1;349=1;352=1;353=1;354=1;356=1;359=1;360=1;361=1;362=1;363=1;367=1;368=1;369=1;371=1;372=1;374=1;375=1;376=1;377=1;378=1;381=1;382=1;383=1
+
+ncloc_data2
+17=1;19=1;20=1;21=1;22=1;23=1;24=1;26=1;27=1;28=1;29=1;32=1;33=1;35=1;37=1;38=1;40=1;41=1;43=1;45=1;47=1;48=1;49=1;50=1;51=1;52=1;53=1;54=1;55=1;56=1;57=1;58=1;59=1;60=1;61=1;62=1;63=1;64=1;65=1;66=1;67=1;68=1;70=1;71=1;72=1;73=1;74=1;75=1;76=1;77=1;78=1;79=1;80=1;81=1;82=1;83=1;85=1;86=1;87=1;92=1;93=1;94=1;95=1;96=1;97=1;98=1;99=1;104=1;105=1;106=1;107=1;108=1;109=1;110=1;111=1;112=1;117=1;118=1;119=1;120=1;121=1;122=1;123=1;124=1;129=1;130=1;131=1;132=1;133=1;134=1;135=1;136=1;137=1;142=1;143=1;144=1;145=1;146=1;147=1;148=1;149=1;150=1;155=1;156=1;157=1;158=1;159=1;160=1;161=1;162=1;163=1;168=1;169=1;170=1;171=1;172=1;173=1;174=1;175=1;176=1;181=1;182=1;183=1;184=1;185=1;186=1;187=1;192=1;193=1;194=1;195=1;196=1;197=1;198=1;203=1;204=1;205=1;206=1;207=1;208=1;209=1;210=1;211=1;213=1;214=1;215=1;217=1;218=1;219=1;220=1;221=1;222=1;224=1;225=1;226=1;227=1;228=1;229=1;230=1;231=1;233=1;234=1;235=1;236=1;237=1;238=1;239=1;240=1;241=1;242=1;243=1;244=1;245=1;247=1;248=1;249=1;250=1;251=1;252=1;254=1;255=1;256=1;257=1;258=1;259=1;260=1;261=1;266=1;267=1;268=1;273=1;274=1;275=1;276=1;281=1;282=1;283=1;284=1;289=1;290=1;291=1;292=1;293=1;295=1;296=1;297=1;298=1;299=1;300=1;302=1;303=1;304=1;305=1;307=1;308=1;309=1;310=1;312=1;313=1;314=1;315=1;316=1;317=1;319=1;320=1;321=1;322=1;323=1;325=1;326=1;327=1;328=1;330=1;331=1;332=1;333=1;334=1;336=1;337=1;338=1;339=1;340=1;342=1;343=1;344=1;345=1;347=1;348=1;349=1;350=1;352=1;353=1;354=1;355=1;356=1;358=1;359=1;360=1;361=1;362=1;363=1;365=1;367=1;368=1;369=1;371=1;372=1;374=1;375=1;376=1;377=1;378=1;380=1;381=1;382=1;383=1;384=1;385=1
\ No newline at end of file
diff --git a/src/src/build/sonar/scanner-report/measures-7.pb b/src/src/build/sonar/scanner-report/measures-7.pb
new file mode 100644
index 0000000..4714b89
--- /dev/null
+++ b/src/src/build/sonar/scanner-report/measures-7.pb
@@ -0,0 +1,15 @@
+
+classes
+ functions
+
+complexity-
+
comment_lines
+
+statements
+ncloc
+cognitive_complexity(
+executable_lines_data2
+258=1;261=1;262=1;263=1;265=1;267=1;271=1;275=1;276=1;277=1;278=1;279=1;280=1;282=1;283=1;285=1;286=1;288=1;289=1;290=1;291=1;292=1;293=1;296=1;297=1;302=1;54=1;55=1;56=1;57=1;58=1;59=1;60=1;61=1;68=1;69=1;70=1;71=1;72=1;73=1;74=1;76=1;77=1;78=1;79=1;80=1;84=1;85=1;91=1;92=1;93=1;94=1;95=1;96=1;97=1;99=1;100=1;101=1;102=1;104=1;105=1;106=1;108=1;109=1;110=1;111=1;113=1;114=1;115=1;116=1;117=1;120=1;121=1;122=1;123=1;126=1;129=1;130=1;134=1;135=1;136=1;137=1;138=1;139=1;142=1;144=1;145=1;147=1;152=1;153=1;154=1;155=1;156=1;158=1;159=1;160=1;162=1;164=1;167=1;170=1;171=1;172=1;176=1;177=1;178=1;181=1;186=1;187=1;188=1;189=1;190=1;191=1;192=1;193=1;195=1;196=1;201=1;202=1;205=1;206=1;208=1;209=1;210=1;212=1;213=1;214=1;215=1;216=1;219=1;221=1;222=1;223=1;225=1;227=1;232=1;233=1;234=1;235=1;236=1;237=1;238=1;239=1;241=1;242=1;243=1;244=1;245=1;247=1;248=1;249=1;251=1;252=1;253=1;254=1;255=1
+
+ncloc_data2
+17=1;20=1;21=1;22=1;23=1;24=1;25=1;26=1;27=1;28=1;29=1;30=1;32=1;33=1;34=1;35=1;38=1;39=1;41=1;43=1;45=1;46=1;47=1;48=1;50=1;51=1;53=1;54=1;55=1;56=1;57=1;58=1;59=1;60=1;61=1;62=1;68=1;69=1;70=1;71=1;72=1;73=1;74=1;76=1;77=1;78=1;79=1;80=1;82=1;83=1;84=1;85=1;86=1;88=1;89=1;90=1;91=1;92=1;93=1;94=1;95=1;96=1;97=1;98=1;99=1;100=1;101=1;102=1;103=1;104=1;105=1;106=1;107=1;108=1;109=1;110=1;111=1;112=1;113=1;114=1;115=1;116=1;117=1;118=1;120=1;121=1;122=1;123=1;124=1;125=1;126=1;127=1;129=1;130=1;131=1;133=1;134=1;135=1;136=1;137=1;138=1;139=1;140=1;141=1;142=1;143=1;144=1;145=1;146=1;147=1;148=1;150=1;151=1;152=1;153=1;154=1;155=1;156=1;157=1;158=1;159=1;160=1;161=1;162=1;163=1;164=1;165=1;166=1;167=1;168=1;170=1;171=1;172=1;173=1;176=1;177=1;178=1;179=1;181=1;182=1;184=1;185=1;186=1;187=1;188=1;189=1;190=1;191=1;192=1;193=1;194=1;195=1;196=1;201=1;202=1;203=1;204=1;205=1;206=1;207=1;208=1;209=1;210=1;211=1;212=1;213=1;214=1;215=1;216=1;217=1;218=1;219=1;220=1;221=1;222=1;223=1;224=1;225=1;226=1;227=1;228=1;230=1;231=1;232=1;233=1;234=1;235=1;236=1;237=1;238=1;239=1;240=1;241=1;242=1;243=1;244=1;245=1;246=1;247=1;248=1;249=1;250=1;251=1;252=1;253=1;254=1;255=1;256=1;257=1;258=1;259=1;261=1;262=1;263=1;264=1;265=1;266=1;267=1;268=1;270=1;271=1;272=1;274=1;275=1;276=1;277=1;278=1;279=1;280=1;282=1;283=1;284=1;285=1;286=1;287=1;288=1;289=1;290=1;291=1;292=1;293=1;294=1;296=1;297=1;299=1;300=1;302=1;303=1;305=1;306=1
\ No newline at end of file
diff --git a/src/src/build/sonar/scanner-report/measures-8.pb b/src/src/build/sonar/scanner-report/measures-8.pb
new file mode 100644
index 0000000..4e44f07
--- /dev/null
+++ b/src/src/build/sonar/scanner-report/measures-8.pb
@@ -0,0 +1,15 @@
+
+classes
+ functions
+
+complexity
+
comment_lines
+
+statements
+ncloc3
+cognitive_complexity
+executable_lines_data2y
+w64=1;35=1;36=1;37=1;69=1;38=1;70=1;39=1;40=1;41=1;74=1;44=1;79=1;49=1;54=1;55=1;57=1;58=1;59=1;60=1;29=1;61=1;62=1;31=1
+
+ncloc_data2
+17=1;19=1;20=1;22=1;24=1;25=1;28=1;29=1;31=1;33=1;34=1;35=1;36=1;37=1;38=1;39=1;40=1;41=1;43=1;44=1;45=1;47=1;48=1;49=1;50=1;52=1;53=1;54=1;55=1;56=1;57=1;58=1;59=1;60=1;61=1;62=1;63=1;64=1;66=1;67=1;69=1;70=1;72=1;73=1;74=1;75=1;77=1;78=1;79=1;80=1;82=1;83=1
\ No newline at end of file
diff --git a/src/src/build/sonar/scanner-report/measures-9.pb b/src/src/build/sonar/scanner-report/measures-9.pb
new file mode 100644
index 0000000..7029224
Binary files /dev/null and b/src/src/build/sonar/scanner-report/measures-9.pb differ
diff --git a/src/src/build/sonar/scanner-report/symbols-10.pb b/src/src/build/sonar/scanner-report/symbols-10.pb
new file mode 100644
index 0000000..867ca11
--- /dev/null
+++ b/src/src/build/sonar/scanner-report/symbols-10.pb
@@ -0,0 +1,173 @@
+
+ &:: "
+ "
+1 <
+1 <(
+ $HH RR +YY +
+ JJ UU
+ UU$ *\\ &
+
+ .
+
+
+
+ .
+ "
+* /
+
+
+# .,, ,, ',,3 >,,H S-- ee (ee: Egg +kk% 0kkK Vnn +rr$ /rrH Stt +xx' 2xxG Rzz +~~) 4~~K V
+ +
+
+
+
+
+
+A L
+# .
+ '
+# 0NN %ll "
+# .
++ 6
+. 9
+1 6
+G L
+ ( >
+ ,
+"" dd1 >
+* 78
+## dd %
+
+
+ &
+&&
''& -.
+'' #
+
+
+ *
+)) 'MM eeL V
+ !
+
+++! 0
+00 *]] *
+22 1^^$ 9
+44 /__# 6
+66 6``& @
+88 6aa( BB
+:: ,KK VV
+ "
+ )
+ )t
+<< LL WW ff mm ss yy
+
+
+ z
+>> MM ]] ff ii
+ &
+
+
+0 7
+0 7
+ >
+@@ NN ^^ mm 'pp
+& 3>
+BB OO __ ss &vv
+$ 0>
+DD "PP `` yy *||
+" 3@
+FF $QQ aa +
+
+" 3
+HH )RR YY gg nn tt zz
+
+% 4
+
+
+B Q
+
+: I
+: I
+
+
+JJ
+JJ "KK "
+
+UU
+UU "VV "
+UU+ ,XX
+\\ XX <
+\\' (]] ^^ __ `` aa
+
+dd n
+dd& (ee ee/ 1kk kk> @rr rr; =xx "xx< >~~" $~~> @(
+ee
ff$ *gg0 6ii (
+kk mm/ ;nn7 Cpp $(
+rr ss. 9tt5 @vv "(
+xx
yy. >zz3 C|| ,,
+~~ 3 C
+3 C
+ ,
+
+ T
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ $
+
+
+* 0
+1 7
+
+: I
+
+P W
+
+
+# &
+
+' (
+/ 0
+
+ (
+ $
+
+. 4
+/ 5
+
+> M
+
+
+T [
+G N0
+
+
+
+
+
+
+ $
+
+ "
+! '
+% +$
+
+, ;
+* 9
+- <$
+
+B I
+; B
+= D
+
+
\ No newline at end of file
diff --git a/src/src/build/sonar/scanner-report/symbols-11.pb b/src/src/build/sonar/scanner-report/symbols-11.pb
new file mode 100644
index 0000000..f79cf72
--- /dev/null
+++ b/src/src/build/sonar/scanner-report/symbols-11.pb
@@ -0,0 +1,698 @@
+"
+ )
+ $
+ *
+ &[[ 8
+ $yy
+ +
+ +
+ +6
+ YY }}
+
+ :
+
+$ *
+
+ &
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ "
+
+
+
+
+' ,
+' ,
+1 6
+8 =
+
+8 =
+
+; @
+
+ %
+> C
+
+. 3
+
+# (
+B G
+5 :
+5 :
+
+ "
+# .
+! ,
+3 >
+# .// // '//6 A00 00& 100B M11 11% 011< G11Q \22 22# .22< G33 33( 333F Q44
+ '
+# .
+* 5
+# .
+( 3
+$ /
+D O
+( 3
+# .
+# .
+B M
+( 3
+* 5
+! ,
+( 3
+) 4
+ +
+( 3
++ 6
+! ,
+( 3
+- 8
+ +
+( 3
+- 8
+! ,
+( 3
+) 4
+! ,
+( 3
+* 5
+# .
+( 3
+$ /
+D O
+( 3
+( 3
+M X
+( 3
+* 5
+ +
+( 3
+- 8
+! ,
+( 3
+ $
+ $
+ $
+ $
+ $
+ $
+ $
+ $
+ $
+ $
+ $
+ $
+ $
+ $
+ $
+ '
+ '
+ '
+ '
+A L
+' 2
+ )
+ )
+= H
+( >
+ 0F
+ -
+/ ?
+6 F
+ '
+ '
+ '"
+ +
+ #
+; I.
+""
+
+
+* 3"
+##
+
+ v
+$$
+ (
+
+
+
+
+ *
+
+" ,
+ 8
+&& {{
+ !
+ !
+ !
+))
**& -
+** #
+
+
+
+
+
+
+
+
+
+ .
+,, '
+
+T ^
+ !
+..! 0
+? N
+77 %
+ !
+99 /
+ 2
+;; .
+ 0
+== /
+! 4
+?? 1
+" 7
+AA 0
+" 6
+
+CC .
+EE ,
+ .
+GG *
+ -
+II '
+ $
+KK ,
+ -
+MM .
+ 1
+
+OO *
+
+QQ 1
+
+SS 3
+
+UU +
+WW *
+ +P
+YY ~~
+
+
+/ 7
+Y a
+. 6h
+[[ ,
+
+
+
+
+ &
+ -
+ -
+]]
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+__
+
+
+' *
+! $
+
+) ,
+) ,
+
+
+
+
+# &
+
+
+; >
+' *
+3 6
+# &
+ F
+aa
+
+
+! +
+
+3 =F
+cc
+
+
+! +
+
+2
+ $
+
+ #
+$ -
+& /0
+
+
+( *
+8 :
+ 0
+
+
+/ 8
+B K
+ &0
+
+
+/ 8
+A J
+ &0
+
+
+1 ;
+B L
+ )0
+
+ !
+3 @
+D Q
+! .0
+
+ !
+2 >
+C O
+ ,0
+
+
+. 6
+? G
+ $0
+
+
+2 9
+= D
+ "0
+
+
+* .
+: >
+ 0
+
+
+. 6
+? G
+ $0
+
+
+0 :
+A K
+ (0
+
+ !
+2 >
+F R
+ ,0
+
+
+ !
+8 9
+> ?0
+
+ #
+
+& *
+' +H
+
+ #
+ '
+
+
+& -
+
+
+ #
+ &$
+
+% )
+* .
+* .
+
+
+
+
+ <
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+8 <
+
+
+
+8 <$
+
+ #
+ !
+8 A
+
+ $
+& -$
+
+ #
+
+& *
+
+
+
+
+ $
+
+! #
+
+3 5
+
+
+
+" %
+2 5
+
+
+
+ %
+1 7
+
+ "
+
+
+
+
+
+
+
+
+
+ $
+
+ .
+ $
+( 7
+
+
+# &
+
++ ,
+3 4
+
+ $
+ 0
+
+
+
+
+
+
+ $
+
\ No newline at end of file
diff --git a/src/src/build/sonar/scanner-report/symbols-12.pb b/src/src/build/sonar/scanner-report/symbols-12.pb
new file mode 100644
index 0000000..8290215
--- /dev/null
+++ b/src/src/build/sonar/scanner-report/symbols-12.pb
@@ -0,0 +1,306 @@
+
+
+ #"
+
+ !
+ !
+ bb
+
+
+
+
+
+
+
+
+
+
+
+
+
+ .
+ "
+5 :
++ 0
++ 0F
+# .
+8 C
+/ :
+ $
+8 C
+! ,"
+# 0
+P ]
+P ]F
+# .
+ +
+ $
+ $
+ )
+A L,
+( >dd ,
+ ,
+ 0
+ ->> #?? $BB #EE #II 'JJ 'KK 'LL $NN +PP #SS #VV #WW $ZZ #^^ 'oo #pp $ss #vv #zz '|| +~~ ' #
+ +
+( 8
+ +
+/ ?
+ +
+) 9
+ +
+* :
+ +
+- =
+ +
+/ ?
+" 2
+ +
+3 C
+6 F
+ '
+ '
+: J
+= M
+3 C
+3 C:
+
+
+
+* 3
+ P
+ aa
+
+ "
+
+
+ "
+ ** 99 :: :: &HH HH$ .jj kk kk &yy yy$ .
+' 1
+& 0
+
+
+
+
+$ .
+
+& 0
+
+& 0
+
+
+ *
+ 6
+##
$$& *,,
+ $
+
+$$ #bb
+
+
+
+
+
+
+
+
+
+
+
+
+
+ ,
+&& 22
+
+ ,
+(( 33
+
+
+** 66
+
+" +
+& /
+
+
+
+
+% .
+ $
+ @
+,, 44 ]] ^^E R
+
+ !J
+.. 55 EE6 =SS: AZZ8 ?
+
+
+
+00
+
+99 %
+99* 2BB: Bd
+:: >> BB EE PP SS VV ZZ ^^ gg <
+HH II JJ KK NN PP= C
+aa bb
+
+jj %
+jj* 2ss: B>
+kk oo ss vv
+ 2
+yy zz || ~~ = C
+
+
+
+
+ &
+
+2 4
+
+
+
+
+$ &
+
+
+
+
+
+ !
+
+! #
+
+# $
+
+
+ %T
+
+1 3
+
+
+
+
+" $
+& (
+
+
+ $
+
+ #
+$ -
+& /0
+
+
+ !
+8 9
+> ?$
+
+ #
+) -
+ $
+
+
+
+
+ -$
+
+
+
+. 20
+
+
+
+
+ $
+
+
+
+8 <$
+
+ #
+
+8 A$
+
+
+
+ "
+
+
+ $
+
+ #
+$ -
+& /0
+
+
+ !
+8 9
+> ?$
+
+ #
+) -
+
+
+
+
+
+ 0
+
+% -
+
+ (
++ 3
+
+# $
+
+
+ H
+
+$ %
+
+
+
+
+ <
+
+
+
+
+
+0 8
+
+
+
+
+
+
+
+
+
+% .
+ #
+
+
+
+
+ %
+
+
+
+
+% 1
+ )
+
+
+
+# )
+
+
+ d
+
+ MM NN> F{{ ||> F
+) 1
+4 <
+
+* 2
+
+
+
+
\ No newline at end of file
diff --git a/src/src/build/sonar/scanner-report/symbols-13.pb b/src/src/build/sonar/scanner-report/symbols-13.pb
new file mode 100644
index 0000000..e6bcac7
--- /dev/null
+++ b/src/src/build/sonar/scanner-report/symbols-13.pb
@@ -0,0 +1,305 @@
+
+
+ #
+ EE bb }}
+
+
+
+
+
+
+
+
+
+
+
+ R
+ "
+7 <
+> C
+: ?
+? D
+- 2
+- 2j
+# .
+" -
+3 >
+) 4
+' 2
+, 7
+ "
+ &
+ &(
+( >GG ,dd , 0
+ -33 #44 $77 #:: #>> '?? '@@ 'AA $BB #RR #SS $VV #YY #]] '^^ '__ #nn +oo( 8ss +tt/ ?xx +yy) 9
+" 2
+5 E
+ ,
+ 0
+G W
+ 0
+" 2
+% 5
+2 B
+" 2
+) 9
+ #@
+ DD aa || "
+ "
+
+ .. // // &== ==$ .MM NN NN &\\ \\$ .jj' 1
+& 0
+
+
+
+ *
+
+$ .*
+ && ** !
+
+!!
""& .
+"" #EE bb }}
+
+ !
+
+
+
+
+
+
+
+
+
+ 6
+$$ ++ ::6 <
+
+
+&& %**
+
+ &
+
+% .
+B K
+ &
+! *
+
+
+ #
+ "
+ %
+
+
+ &
+
+0 9
+" +
+
+ %
+
+
+" +
+
+ "
+
+
+((
+
+.. %
+..* 277: B<
+// 33 77 :: BB JJ 2
+== >> ?? @@ BB= C
+DD EE
+
+MM %
+MM* 2VV: B<
+NN RR VV YY __ gg (
+\\ ]] ^^ __= C
+aa bb
+
+jj &P
+jj2 4kk nn oo ss tt$ &xx yy
+||# $}}
+
+ %<
+
+1 3
+
+
+
+$ &H
+
+ !
+
+" (
+ !
+
+ #
+
+
+C G
+
+# $
+
+
+ -$
+
+
+
+ <
+
+
+
+
+
+4 :T
+
+
+
+ '
+ "
+, 6
+
+ !
+
+
+
+
+ <
+
+$ %
+
+
+
+
+
+
+
+
+
+
+ H
+
+% )
+
+0 4
+ $
+
+ 0
+
+
+
+
+
+
+
+) 5H
+
+% )
+$ (
+
+! %
+
+* .`
+
+/ 4
+
+
+
+
+( -
+
+* /
+
+
+ $
+
+
+
+! (0
+
+
+
+
+
+
+ "
+ <
+
+( ,
+& *
+# '
+
+ 0
+
+
+
+
+ H
+
+
+
+
+" '
+ !
+> C
+
+ 0
+
+& *
+$ (
+ $
+6 :<
+
+0 5
+
+
+
+< A$
+
+
+
+
+
+ "
+
+* -
+" %0
+
+
+
+. /
+# $$
+
+
+
+
+
+
+
+& *
+! %
+
+ #0
+
+( -
+
+
+ "
+
+
+
+( +
+% ($
+
+
+
+
+
+ +
+
+
+
+ "
+
+
+
\ No newline at end of file
diff --git a/src/src/build/sonar/scanner-report/symbols-14.pb b/src/src/build/sonar/scanner-report/symbols-14.pb
new file mode 100644
index 0000000..525898d
--- /dev/null
+++ b/src/src/build/sonar/scanner-report/symbols-14.pb
@@ -0,0 +1,14 @@
+
+
+
#
+
+ .
+
+ !
+
+ !
+) 4
+
+ !
+) 4
+@ N )
\ No newline at end of file
diff --git a/src/src/build/sonar/scanner-report/symbols-15.pb b/src/src/build/sonar/scanner-report/symbols-15.pb
new file mode 100644
index 0000000..2a8fd74
--- /dev/null
+++ b/src/src/build/sonar/scanner-report/symbols-15.pb
@@ -0,0 +1,14 @@
+
+
+
$
+
+ .
+
+ "
+
+ "
+* 5
+
+ "
+* 5
+A O )
\ No newline at end of file
diff --git a/src/src/build/sonar/scanner-report/symbols-16.pb b/src/src/build/sonar/scanner-report/symbols-16.pb
new file mode 100644
index 0000000..d19eac1
--- /dev/null
+++ b/src/src/build/sonar/scanner-report/symbols-16.pb
@@ -0,0 +1,47 @@
+2
+ CC CC( 4EE ,FF )
+ &** 33 -(
+ GG II )MM )(
+ (( 00 !44" )
+ IIG MMMG M
+ $ -
+ CC5 6HH dd* +kk tt uu xx xxF Gzz zzF G|| }}
+ ,NN %(
+ 2JJ +ddH _vv #
+
+
+"" 1__ 8
+$$ '.. 00+ =
+%%
+( 2
+(( 11 33/ 7CCN VII6 >IIN VMM6 >MMN Vdd ee$ ,ff! )ll mm (tt6 >vv4 <xx3 ;zz3 ;||5 =
+** .33 __ 2
+,, %55 99 ff uu3 ?*
+.. 222
+ '
+
+00
+00" )11
+00> F22 &
+
+88
+<< dd
+<<& ->> <
+BB !kk tt xx zz ||
+BB& .DD #HH
+
+BB7 >(
+CC !EE FF __: F
+GG #II MM
+
+cc $
+
+cc- 3
+
+jj #
+jj. 6kk2 :mm8 @
+
+rr 2
+rr) /ss ww yy {{
+
+
\ No newline at end of file
diff --git a/src/src/build/sonar/scanner-report/symbols-17.pb b/src/src/build/sonar/scanner-report/symbols-17.pb
new file mode 100644
index 0000000..6e1b434
--- /dev/null
+++ b/src/src/build/sonar/scanner-report/symbols-17.pb
@@ -0,0 +1,806 @@
+D
+ [[
+
+
+
+ .
+ &
+
+( 6
+2 @
+ ,
+
+ #
+ ,
+ rr !
+& .
+$ ,
+
+ "
+
+ #
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ "
+# '
+ "
+ "
+# '
+
+ .
+# +
+ '
+$ ,
+8 @
+ ( >
+ ,
+ ,
+ ,
+ ,
+ ,
+ 0
+ ,
+ ,
+ ,
+ ,
+ ,
+!!( ?
+9 P
+ -
+ -
+- D
+9 P
+& =
+0 G
+ *
+- D
++ B
+ -
+ -
+8 O
+"" -
+ '
+ '
+ $
++ ;
+ '
+ '
+ $
+/ ?
+ +
+ +
+ '
+ $
+ '
+ '
+ +
+ '
+ '
+ +
+ '
+ '
+ '
+ '
+6 F
+ '
+ $
+ '
+ '
+ '
+ '
+ '
++ ;
+## 2< S
+ 4
+%% !
+& 0.
+&& #
+
+
+ "
+'' 5
+ (
+ ("
+((% 9
+
+. B:
+))& -
+
+" )
+
+" ):
+**& .
+
+
+ (
+ "
+++ $
+
+ "
+,,# 3
+
+5 E
+--# 4MM
+ +.
+.. 1
+ )
+A S
+ +
+// -
+( 7"
+00 2
+
+
+11 (
+
+22 0
+
+33 ]]
+
+' 0
+
+' 0
+# ,
+
+' 0
+
+' 0
+
+
+
+' 0v
+44
+
+
+
+
+ "
+
+
+
+
+55
+
+ *
+
+# -
+ !
+
+$ .
+
+
+# -
+
+$ .
+
+
+# -
+
+( 2
+
+$ .
+
+$ .
+
+$ .
+
+ *
+
+$ .
+
+$ .
+ "
+77
+B P
+Z h.
+88
+@ K
+
+
+99
+ "
+::
+
+( 9"
+;;
+
+6 @
+<<
+
+== $
+ '"
+>>
+
+$ ,
+?? (
+ +2
+BB
CC& 1KK kk *mm '
+CC #
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+EE )
+2 ;
+GG -aa
+ #
+II .bb !
+ %(
+KK (ll mm oo h
+MM )``
+
+
+0 ;
+ "
+# .
+$ /
+ "D
+OO aa
+
+
+ %
+* 18
+QQ bb
+
+
+) 1h
+SS cc
+
+C Q
+C Q
+G U
+C Q
+C Q
+C Q|
+UU dd zz ~~
+
+
+
+
+
+
+
*
+WW ee yy
+
+YY ff
+ \
+[[ gg
+
+C K
+
+ $
+
+
+]] "hh
+
+D P
+
+
+( 4
+
+
+
+
+
+__ mm '
+
+kk+ 6
+
+rr :
+rr" *
+, 4
+. 6
+ (
+! )
+uu
xx
+vv
xx" #
+ww
xx& '
+xx yy %0
+
+
+
+* 3
++ 40
+
+
+
+
+
+
+
+4 9
+
+
+ 0
+
+ %
+ -
+ "
+ *<
+
+/ 7
+; C
+H P
+' /
+# +
+
+A P
+ <
+
+
+
+A J
+
+ 0
+
+ %
+ +
+< J
+ $
+
+
+
+ !
+
+
+ )<
+
+
+
+
+
+X _$
+
+
+
+
+
+% 9
+% 9
+
+ "
+ '
+
+ $
+
+ #
+
+
+
+- 5
++ 3<
+
+> G
+ !
+
+
+ %$
+
+
+
+
+
+& /
+3 <
+
+
+B S
+
+
+: G0
+
+ !
+2 @
+* 8
+, :
+
+ .
+# 8
+
+
+* 2
+
+
++ 2$
+
+ !
+
+2 :
+
+
+! ($
+
+ !
+ !
+
+
+
+ 0
+
+
+ !
+
+ $$
+
+
+* 1
+7 >
+
+
+, 10
+
+
+
+, 1
+/ 40
+
+
+ "
+4 7
+I L$
+
+
+
++ 3
+
+
+
+
+
+
+
+ T
+
+
+0 ;
+4 ?
+2 =
+> I
+0 ;
+> I
+
+ #
+ *0
+
+
+
+
+ 0
+
+ %
+ 1
+ 0
+ 1H
+
+1 7
+
+ $
+ "
+( .
+, 2T
+
+
+
+& 5
+
+' 6
+ "
+. =<
+
+
+
+
+: ?
+
+
+
+A I
+
+ !
+i l
+
+Q S
+ 0
+
+
+
+
+ $
+
+
+
+ #T
+
+ "
+$ /
+$ /
+
+
+
+$ /
+
+. 0
+1 3$
+
+
+
+8 @$
+
++ /
+
+C G
+
+! '
+ %
+
+ !
+1 9
+
+
+" *
+
+) *
+
+
+
+
+
+
+
+
+
+
+
+ $
+
+ $
+
+ 0
+
+
+
+
+0 6$
+
+
+
+@ J
+
+ !
+/ 9
+
+
+
+
+
+
+
+ $
+
+( 0
+ #
+ 0
+
+
+
+
+0 6$
+
+
+
+@ J
+
+ !
+/ 9
+
+
+ $
+
+
+ T
+
+
+
+
+
+
+
+ 0
+
+ !
+
+
+ "
+
+# $
+
+
+ $
+
+# '
+
+ !
+
+ 0
+
+ "
+7 ;
+* .
+I M0
+
+- 6
+
+@ I
+ <
+
+A J
+ &
+@ I
+ &
+B K0
+
+
+
+
+ $
+
+
+
+@ Jl
+
+
+
+
+
+
+
+
+
+ !
+
+
+
+
+ $
+
+ $
+
+ 0
+
+
+
+
+ $
+
+
+
+@ J
+
+
+
+
+ !
+
+
++ 2$
+
+ !
+
+2 :0
+
+
+ !
+
+ $$
+
+
+* 1
+7 >
+
+
+, 10
+
+
+
+, 1
+/ 40
+
+
+ "
+4 7
+I L$
+
+
+
++ 3
+
+
+
+
+) *
+
+
+
+
+
+
+
+
+
+
+( /
+< C0
+
+
+
+
+0 6$
+
+
+
+@ JH
+
+
+
+
+
+
+ !
+
+ !
+
+
+
+
+
+ !% 3
+
+
\ No newline at end of file
diff --git a/src/src/build/sonar/scanner-report/symbols-18.pb b/src/src/build/sonar/scanner-report/symbols-18.pb
new file mode 100644
index 0000000..403440d
--- /dev/null
+++ b/src/src/build/sonar/scanner-report/symbols-18.pb
@@ -0,0 +1,992 @@
+
+ BB mm0 8
+ &FF "
+ "
+' 2
+0 ;"
+ $
+ %
+3 @
+ DD rr ^
+
+
+
+8 >
+, 2
+* 0
+- 3
+
+ tt
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ "
+
+8 9
+8 9
+ "
+' ,
++ 0
+N S
+' ,
++ 0
+L Q
+B G
+
+. 3
+) .
+' ,
+' ,
+2 7
+- 2
+' ,
++ 0
+N S
+0 5
+0 5
+$ )
+
+# (
+( -
+' ,
++ 0
+N S
+K P.
+# .
+% 0
+7 B
+, 7^
+# .
+ "
+ "
+! ,
+/ :
+( 3
+ "
+# .Z
+# +PP $__+ 3
+
+0 8
+
+
+ '
+ # 'NN ^^, 0
+
+& *
+' +
+' +
+# '
+ "
+ "
+
+& *
+" &
+* .
+& *
+' +
+' +
+" &
+- 1
+
+
+
+
+
+
+
+
+
+ "
+! %
+ #
+
+
+
+" &
+
+!!# *
+? F
+& -
+4 ;
+? F
+& -
+5 <
+0 7
+( /
++ 2
+" )
+? F
+& -
+? F
+& -
+5 <
+0 7
+( /
+4 ;
+0 7
+
+ %
+ %
+ %
+ !
+
+
+
+ %
+
+ %
+. 5
+? F
+- 4
+* 1v
+""# '
+
+( ,
+, 0
+) -
+A E
+
+
+
+
+### +LL $RR ]]0 8
+$ ,
+ (
+
+, 4
+# +
+ &
+ $
+
+' /
+" *
+
+ '
+
+ v
+$$( >
+ '
+ ,
+ 0
+ 0
+ 0
+ ,
+ 0
+ 0
+" 8
+%%( ?
+ 5
+ (
+( ?
+& =
+% <
+I `
+0 G
+= T
+; R
+> U
+F ]
+- D.
+&& &
+
+ %
+ )
+'' -
+. >
+/ ?
+ 0
+G W
+" 2
+ *
+. >
+/ ?
+$ 4
+( 8
+" 2
+/ ?
+ ,
+C S
+ 0
+* :
+ $
+; K
+ $
+; K
+ +
+7 G
+ +
+: J
+ 0
+ .
+ .:
+))
+
+
+
+ "
+**
+
+ "^
+++
+
+" ,
+
+" ,
+
+
+ "n
+-- LL NN PP VV XX ]] '^^ #__ "bb cc
+.. TT aa '.
+//
+
+
+ R
+00
+
+
+
+
+
+ 2
+33
44& 2@@ ff +hh (
+44 #tt
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ !
+
+66 )
+3 @
+88 /
+ &"
+:: 0
+ '
+ '
+<< 2uu )
+>> 0
+ 0(
+@@ )gg hh jj
+BB oo
+" +
+DD ww xx #
+% -
+% -
+& .
+& .
+& .
+" *
+ &
+& .
+& .
+FF ,xx
+
+
+, <
+
+
+
+: J
+> N
+
+ (4
+HH [[ ss yy
+
+JJ \\ zz
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ ~
+LL& 7]] {{
+
+ %
+5 F
+
+9 J
+ !
+% 6
+
+NN" /^^ ||
+
+ !
+ )
+ (
+ %
+ (
+ %
+1 >
+ $
+ !
+ (
+ %
+ (
+ %
+
+
+ %
+ %
+
+ -
+ %~
+PP& 2__ }}
+
+ ,
+- 9
+ #
+ #
+ ,
+
+
+RR ``
+
+
+
+ %
+
+
+
+9 B
+ Z
+TT +aa ~~
+
+
+ %
+> O
+ !
+VV" +bb
+
+ !
+
+ !
+ !
+ %
+
+1 :
+
+XX" +cc
+
+
+ !
+
+ !
+ !
+
+ (
+
+" +
+ZZ hh (
+
+ff, 7
+
+mm /
+mm9 Aoo
+
+rr
+rr #ww "
+rr4 =
+
+ $
+
+
+
+
+
+) *
+
+
+( )
+
+
+
+ $
+
+
+
+ 0
+
+
+$ *
+( .
+( .<
+
+ !
+ +
+$ /
+ +
+$ /0
+
+
+
+6 7
+> ?H
+
+ !
+ #
+ $
+5 ;
+
+8 >
+
+
+; >
+
+
+ $
+
+ %
+( /
+. 50
+
+
+$ %
+: ;
+D ET
+
+! )
+
+ $
+3 ;
+ (
+1 9
+K S0
+
+
+
+6 7
+> ?T
+
+ !
+ #
+ $
+4 :
+
+ $
+4 :T
+
+
+* -
+& )
+; >
+
+> A
+. 1$
+
+
+
+ <
+
+ %
+
+/ 7
++ 3
+ $$
+
+ %
+( /
+. 50
+
+
+$ %
+: ;
+D EH
+
+ !
+
+
+
+2 6
+3 7
+
+
+
+
+
+ <
+
+
+
+ $
+ $
+" *
+
+
+
+
+
+
+I J
+* +
+
+
+
+
+
+
+
++ ,
+& '
+6 7
+
+2 3
+
+
+ l
+
+
+
+- 0
+- 0
+
+- 0
+- 0
+& )
+D Gx
+
+
+
+
+C G
+
+
+# '
+, 0
+
+: >$
+
+* .
+
+, 0
+
+$ )
+
+
+( )
+
+
+
+
+
+
+
+
+
+L M
+E F
+
+
+
+
+
+
+
+P Q
+I J
+
+
+
+
+
+
+
++ ,
+& '
+6 7
+
+2 3
+
+
+
+
+
+
+) ,
+) ,
+" %
+? B
+
+- 0
+- 0
+& )
+J M
+
+- 0
+- 0
+& )
+D G
+
+* -
+% (
+
+
+
+
+
+F J
+? C
+
+
+ !
+J N
+C G
+
+
+# '
+, 0
+
+> B<
+
+
+
+ $
+ $
+" *$
+
+. 2
+
+0 4$
+
+( -
+
+
+
+, -x
+
+
+ %
+ !
+
+ %
+ !
+ )
+ %
+ !
+ !
+
+# +
+ `
+
+2 6
+ !
+ "
+( ,
+5 9
+ $
+! %
+! %T
+
+? @
+$ %
+( )
+& '
+& '
+' (
+' (T
+
+
+
+
+9 =
+
+
+9 =
+
+
+
+
+# '
+
+
+
+# '
+
+2 6
+
+
+' +
+
+
+
+
+
+
+
+
+
+
+
+
+
+% ,
+
+( /H
+
+
+
+& (
+
+* ,
+ !0
+
+ #
+
+" &
+
+
+
+L N$
+
+ '
+( 1
+* 30
+
+
+$ %
+< =
+B C0
+
+# '
+
+* .
+ $
+
+! '
+P V
+
+# $
+ $
+
+
+
+ (
+
+
+ <
+
+& *
+
+
+G K
+
+
+3 4
+( )H
+
+
+
+
+
+
+( /$
+
+
+
+ $
+
+
+
+
+$ (
+
+1 2
+0 1
+
+
+
+' .
+- 4
+, 3
+
+
+ %
+/ 6
+
+
+
+
+" )
+ H
+
+
+
+
+
+
+' (H
+
+
+
+: >
+1 5
+
+ !$
+
+
+
+" +l
+
+
+
+
+
+
+9 A
+& .
+9 A
+ <
+
+
+
+
+
+* 4$
+
+2 6
+
+4 8$
+
+, 1
+ "
+ %$
+
+
+2 5
+- 0$
+
+
+
+ #$
+
+ !
+
+ <
+
+' +
+
+0 4
+
+ #
+
+4 5
+0 1T
+
+
+# *
+( /
+
+0 7
+
+ <
+
+
+% )
+. 2
++ /
+3 70
+
+ "
+
+
+9 F$
+
+
+
+; G0
+
+ "
+! .
+
+H U<
+
+ !
+
+
+
+ <
+
+) ,
+1 4
+! $
+! $
+! $<
+
+6 =
+
+ &
+& -
+& -l
+
+
+
+
+8 @
+
+
+' /
+& .
+5 =
+
+ #
+ l
+
+
+
+
+
+! "
+ !
+
+
+ $
+
+
+2 5
+- 0$
+
+
+
+8 <$
+
+& ,
+
+? E
+
+
+
+
\ No newline at end of file
diff --git a/src/src/build/sonar/scanner-report/symbols-20.pb b/src/src/build/sonar/scanner-report/symbols-20.pb
new file mode 100644
index 0000000..5c23cea
--- /dev/null
+++ b/src/src/build/sonar/scanner-report/symbols-20.pb
@@ -0,0 +1,233 @@
+F
+ /
+ .
+N f
+ $
+ 6
+ 6
+ ,
+ )8
+ "vv
+A L
+A L
+ )b
+ $&& .. ..# 0EE +
+
+
+" /
+" /*
+ ,,1 8gg #
+$ +
+ 4
+ 68
+ 55
+
+
+
+ !
+ (N
+ ;; xx
+
+
+
+ p
+ "22% *556 ;vv+ 0
+B G
+ !
+B G
+ !
+ !
+9 >
+# +
+? G:
+# .
+$ /
+( 3
+$ /
+( 3
+# .00 11 22 33 44 KK 'LL '
+ +
+ +
+ +
+ +
+ # +
+? G"
+""
+
+D M
+
+%%
+&& )EE JJ KK LL dd vvL [{{
+
+
+
+ d
+'' FF PP TT XX \\ `` dd- 6}} ~~
+(( #;; xx
+
+,,$ 0
+,,9 @55
+,,G O44* 2F
+.. 00 11 22 33 44 55N T
+//
00- 811. 9
+55 99" %<
+77
99 << >> ??? EAA
+::' (;;/ 0
+
+DD
+
+II
+II$ 'JJ
+II0 5JJ! &
+
+OO
+OO# &PP !
+OO/ 4PP# (
+
+SS
+SS# %TT "
+
+WW
+
+[[
+[[# %\\ "
+
+__
+__# &`` !
+__/ 4``# (
+cc "ll
+
+gg
+gg$ +uu ~~6 =2
+gg2 8hh iiB HvvC I~~? E
+
+ '' FF F
+
+ XX $
+
+
+
+4 ?
+
+ -
+
+ "
+
+
+
+ #
+ +
+ '
+' 6
+ <
+
+
+
+
+
+4 ?
+
+ -
+
+1 @
+
+
+
+ #
+ +
+ '
+' 6
+ <
+
+$ '
+ !
+ !
+
+
+
+ FF
+
+ dd7 F}} %"
+
+
TT
+ %$
+
+ "
+
+ "
+
+
\\
+ %$
+
+ "
+
+
+
+
``
+
+ #
+ #
+
+, 1
+% *
+
+
PP
+
+ #
+ #
+
+, 1
+% *
+
+ #~~ 50
+
+, 3
+ %
+ %
+6 =`
+
+: @
+
+F L
+9 ?
+M S
+9 ?
+M S
+Q W<
+
+0 =
+ !
+ !
+
+- :T
+
+- 4
+
+
+& -
+
+
+& -
+
+
+3 6
+
+3 4
+
+
+3 6
+
+3 40
+
+, 3
+ #
+/ 6
+F M$
+
+) *
+7 8
+E F$
+
+7 8
+7 8
+E F
\ No newline at end of file
diff --git a/src/src/build/sonar/scanner-report/symbols-21.pb b/src/src/build/sonar/scanner-report/symbols-21.pb
new file mode 100644
index 0000000..e9fb2b3
--- /dev/null
+++ b/src/src/build/sonar/scanner-report/symbols-21.pb
@@ -0,0 +1,420 @@
+"
+ )
+ -
+ )"
+ "
+
+ @
+ ;; mm zz
+. 5
+# *.
+
+
+
+ "
+
+1 :
+
:
+
+
+
+
+ \
+ "vv
++ 0
+< A
+& +
+" '
+A F
++ 0"
+# +
+ "
+ "h
+# .DD EE FF GG HH II JJ
+
+ )"
+# 0
+ %
+ ,
+# .NN OO PP QQ RR SS
+ *
+ *
+ *
+ *
+ &
+Z e
+9 D
+ &
+ &
+ &
+ &
+# +
+ &"
+ , ;
+
+
+
+"" -F
+%%
+
+
+ *
+
+
+'' rr
+
+
+
+* /
+
+
+
+
+
+
+
+
+
+
+
+
+
+)) ss ||
+C J
+, 3
+P W
+# *
+, 3
+W ^
+
+A H
+% ,
+
+
+C JR
+++
+
+C K
+ &
+
+3 ;
+ \
+-- uu
+
+
+B G
+
+< A
+ \
+// oo
+
+
+
+H R
+
+ ,
+11 pp
+
+ R
+33
+
+
+
+1 ;
+
+6 @^
+55
+
+
+
+
+
+E N
+ h
+77 vv
+
+ "
+
+
+
+G R
+ B
+99 qq }}
+
+; D
+ Z
+;; nn {{
+
+
+1 9
+ #
+ :
+== #
+
+ !
+
+ 6
+?? tt ~~
+
+
+AA' A
+ 1
+ *
+ "
+ &
+ &
+@ Z
+ *
+ *
+ *
+ *
+ *
+CC! 0
+T c
+MM! 0
+M \"
+VV +
+; I
+; I
+XX 0
+4 G
+ZZ 2
+3 H
+\\ -
+. >
+^^ 2
++ @
+`` 5
+, D
+bb 4
++ B
+dd 2
+* ?
+ff 4
+, C
+hh 6
+/ H
+mm
+ *
+mm 'nn
+mm. 6qq
+zz
+
+zz '{{
+zz. 4||
+zz; C}}
+
+
+ x
+
+
+
+
+ "
+ #
+ "
+ $
+ #
+ &
+
+
+
+ x
+
+
+
+
+" (
+# )
+ &
+, 2
+, 2
+
+ 0
+
+
+2 6
+> B
+B F
+
+ -
+
+6 =
++ 2
+
+D L
+4 <
+
+R Z
+ !
+
+
+ %
+
+ 0
+ *<
+
+
+
+
+
+
+
+ "
+
++ 2
+ &
+
+9 ;
+( *
+
+ (0
+
+ "
+
+ +
+ #
+
+ !
+
+
+ 1
+
+M N
+% &
+
+ 0
+
+" &
+
+
+; ?
+
+0 3
+A D
+
+
+
+$ (
+
+
+
+
0
+
+! #
+
+
+G I
+
+ 0
+
+% )
+
+I M
+
+
+3 9
+6 <
+
+
+
$
+
+" &
+
+
+
+
+
$
+
+ "
+
+
+
+ $
+
+& *
+( ,
+
+
+ !
+
+) 4
+1 <
+
+; C
+= E
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ "
+
+* 2
+ "<
+
+
+ "
+
+
+
+
+
+& 3
+
+
+
+
+
+
+ '
+@ H
+
+/ 3
+< @
+
+ "
+
+ /AA &
+2 L
+
+
%
++ C
+
+
+' :
+
+& *
+
+4 7$
+
+
++ :
++ :
+
+
#
++ A
+
+( /
+
+5 <
\ No newline at end of file
diff --git a/src/src/build/sonar/scanner-report/symbols-22.pb b/src/src/build/sonar/scanner-report/symbols-22.pb
new file mode 100644
index 0000000..a21fee2
--- /dev/null
+++ b/src/src/build/sonar/scanner-report/symbols-22.pb
@@ -0,0 +1,379 @@
+
+ #
+ @
+ ..7 >FF ~~
+ !
+4 ;:
+
+
+
+
+
+
+ *
+ KK KK0 ;
+ :
+
+! *
+! *
+! *
+ &:
+ %
+N X
+U _
+N X
+
+
+
+
+
+
+
+
+
+
+
+
+ v
+
+@ A
+3 4
+? @
+< =
+3 4
+> ?
+
+0 1
+4 5v
+ "
+E J
+D I
+
+3 8
+= B
+5 :
+C H
+
+. 3R
+# .ii jj kk ll mm nn
+% 0"
+# 0
+ )
+# 0z
+ # .\\ ]] ^^ __
+% 0
+ %
+ )
+ )
+
+J UR
+""
+
+
+
+
+
+
+## $
+ *"
+$$
+
++ ;.
+%%
+
+
+ R
+&&
+9 D
+5 @
+
+
+
+ $(
+))
,, .. *00 '
+** #
+
+
+
+
+
+
+
+
+
+
+ (
+,, (// 00 22
+
+..+ 6
+..? F00( /
+:: 4
+ /
+
+<< 7
+
+>> 0
+@@ .
+ )
+BB )
+ 2
+DD "GG OO SS WW
+FF 00 '
+FF 'GG% ,
+JJ 3
+ )
+
+NN
+
+RR )
+
+VV (
+ZZ #DD GG $.
+[[& 5
+ #
+ #
+ #:
+bb! /
+> L
+0 >
+A O
+= K"
+dd! :
+4 M
+3 L
+ff! 4
+@ S
+hh& 5
+ #"
+qq! 4
+C V
+B U
+ss! 6
+? T
+uu! 6
+? T
+ww! 9
+F ^"
+yy +
+
+
+zz! 3
+? Q"
+{{! 1
+; K
+; K:
+||! 4
+C V
+? R
+C V
+C V
+~~
+
+! )
+ (
+ (
+, 4
+" *
+) 1
+ (
+ (
+4 <
+ %,
+ SS $
+
+ .
+
+ %WW )
+
+
+
+ GG $$
+
+" )
+ !
+ `
+
+
+1 :
+9 B
+5 >
+9 B
+9 B
+5 >
+1 :
+
+% '
+ !
+
+ '
+ *
+
+/ 7
+ $
+
+E G
+
+1 3T
+
+
+
+
+ +
+( 3
+ (
+
+
+ %
+) /$
+
+ %
+ (
+ (
+
+- 3
+ H
+
+A C
+ "
+
+ "
+ "
+ x
+
+
+
+
+* 4
+1 ;
+, 6
+. 8
+- 7
+ '
+ $
+
+ '
+; C
+= E$
+
+# .
+3 >
+( 3
+
+! )
+, 4$
+
+# +
+3 ;
+( 0$
+
+# *
+3 :
+( /
+
+! "
+
+
+ OO 'T
+
+
+
+
+5 7
+
+1 3
+ `
+
+
+
+
+ '
+) 5
+* 6
+ )
+ <
+
+ )
+ &
+ &
+/ 9
+T ^
+
+ '
++ 3T
+
+
+
+
+ *
+( 2
+ '
+
+
+ %
+) /
+
+ 6
+ 70
+
+
+
+
+< @$
+
+
+
+
+
+! $
+% (
+
++ ,
+< =
+
+* +
+< =
+
+! "
+< =
+
+ 3
+ 30
+
+< C
+
+
+" )
+
+I V
+$ 1
+
+\ o
+ #H
+
+
+
+
+
+
+ "
+
+
+ $
+
+
+
+ 0
+
+
+
+ #
+
+
+
+
+
+# $
+8 9
+
+
+9 :
\ No newline at end of file
diff --git a/src/src/build/sonar/scanner-report/symbols-23.pb b/src/src/build/sonar/scanner-report/symbols-23.pb
new file mode 100644
index 0000000..37e2efd
--- /dev/null
+++ b/src/src/build/sonar/scanner-report/symbols-23.pb
@@ -0,0 +1,295 @@
+Z
+ /22 *22J b88 $887 OZZ *ZZJ b\\ $\\7 O
+ ,== !dd !
+ &((+ :KK' 6SS, ;uu) 8
+0 ?
+. =
+. =
+1 @
+B Q
+/ >
+9 H
+( 7L
+ "99 *PP #]] *
+' 2
+' 2
+' 2
+ $LL LL# 0
+ 4EE .ll .t
+ vv
+
+
+
+
+
+
+
+
+ !CC jj
+ ** .. 55 ?? DD FF VV ff kk mm
+
+
+
+
+ "44 99: ?==B GPP3 8]]: ?ddB Gvv& +yy. 3yyQ V
+B G
+N S
+B G
+B G
+' ,
+) .
+9 >
+" '
+' ,
+' ,
+' ,v
+# +
+ (
+
+/ 7
+8 @
+ (
+
+1 9
+
+: B
+# .MM NN OO ^^ )__ )xx xx/ :
+
+/ :
+
+ %
+ %
+ *
+6 A
+
+ +
+ F
+ , >
+ ,
+ "
+" 4
+ *
+8 J2
+"" 22 22@ IZZ ZZ@ IB
+## ((E LSSF M
+
+
+ !
+
+&&
+'' "** .. 55 ?? DD FF VV ff kk mm
+
+ !
+
+
+
+(( *
+((; C==. 62
+((S V)) -- 33 ??9 <
+22, 9:: ==S `
+33 44 99R T
+88- 4:: %(
+==$ +>> >># *>>: A
+CC! "DD/ 0DD= >
+EE/ 0FF/ 0FF= >
+
+KK &
+KK7 ?PP
+KKF HPPK M
+KKO ZNN1 <
+KKa lMM* 52
+LL MM NN OO PPP V
+
+SS +
+SS< Ddd. 6(
+SST WUU [[ ff9 <
+TT ^^5 =
+ZZ, 9`` ddS `
+[[ ]]R T(
+\\- 4^^ __ `` %(
+dd$ +ee ee# *ee: A
+jj! "kk/ 0kk= >
+ll/ 0mm/ 0mm= >
+
+uu (
+uu9 Avv 6
+vv }} ~~
+ "
+ "
+||
+
+
+
+3 4
+< =
+
+ /
+
+@ H
+
+
+O U
+Z `
+
+[ _
+. 20
+
+
+
+
+ $
+
+
+
+
+
+ -
+
+> F
+
+
+M S
+Z `0
+
+
+
+
+ $
+
+
+
+
+
+ -
+
+> F
+
+
+M S
+Z `0
+
+
+
+
+ $
+
+
+
+
+
+ 0
+
+A I
+
+
+R V
+ #0
+
+
+
+
+ $
+
+
+
+
+
+. A
+
+R Z
+
+
+a i
+. 6T
+
+
+
+
+* +
+, -
+
+
0
+
+$ '
+
+
+ 0
+
++ 1
+
+
+ &
+
+7 8
+# $
+
+ .
+
+? G
+
+
+N T
+/ 5<
+
+
+
+ $
+
+
+
+/ 0
+6 7
+
+ 8
+
+I Q
+
+
+Z e
+V a
+
+l t
+/ 7<
+
+
+
+
+ !
+
+
+3 4
+; <
+
+ '
+
+8 @
+ $
+
+G M
+/ 5
+K Q<
+
+
+
+
+
+ $
+
+
+
+
+
+ ,`
+
+4 ;
+
+
+
+
+
+ !
+ $
+
+
+
+/ 4
\ No newline at end of file
diff --git a/src/src/build/sonar/scanner-report/symbols-24.pb b/src/src/build/sonar/scanner-report/symbols-24.pb
new file mode 100644
index 0000000..a3176cf
--- /dev/null
+++ b/src/src/build/sonar/scanner-report/symbols-24.pb
@@ -0,0 +1,95 @@
+
+
+
+
+ 3
+
+ 5
+
+ 5
+
+ <
+
+ <
+
+ :
+
+!! <
+
+## 4
+
+%% 6
+
+'' 8
+
+)) 3
+
+++ 9
+
+-- 9
+
+// 1
+
+11 3
+
+33 5
+
+55 :
+
+77 6
+
+99 5
+
+;; 5
+
+== ,
+
+?? /
+
+AA 7
+
+CC ;
+
+EE 1
+
+GG /
+
+II .
+
+KK 0
+
+MM /
+
+OO 3
+
+QQ :
+
+SS 1
+
+UU 5
+
+WW /
+
+YY .
+
+[[ 4
+
+]] 3
+
+__ .
+
+aa 2
+
+cc -
+
+ee /
+
+gg *
+
+ii 1
+
+kk -
+
+mm -
+
+oo -
\ No newline at end of file
diff --git a/src/src/build/sonar/scanner-report/symbols-25.pb b/src/src/build/sonar/scanner-report/symbols-25.pb
new file mode 100644
index 0000000..8181924
--- /dev/null
+++ b/src/src/build/sonar/scanner-report/symbols-25.pb
@@ -0,0 +1,465 @@
+
+ &:: *
+ B I33A H
+% ,.
+
+
+% +
+
+ && 33 44 PP TT
+
+
+
+
+% +
+
+ %
+
+$ *
+
+$ *
+
+
+- 3
+
+ !
+$ *
+
+
+
+' -
+
+ !
+
+
+# )
+
+
+ % - :"" '33[ h66 "88 ">> &ff, 9
+
+2 ?
+
+ %
+
+, 9
+
+
+
+, 9
+ %
+
+
+, 9
+ %
+
+ ":
+
+
+ "
+
+ "6
+ S V33R U
+
+
+
+
+ ZZ ZZ( .
+
+ .
+
#
+
+& :
+ %N
+ $RR RR) >
+
+' <
+
+' <:
+
+
+
+
+
+ ;;
+
+
+
+ '
+/ 3 (( "
+< @ #(($ (
+J Q% ,((* 1
+W Z. 1((3 6
+` d $$# '
+n s!! (
+ %"" $$ ((8 ?2
+" & 3 7 !!, 0
+ !! !!' *
+&& (( ,,
+)) **
+33 & ((
+33. 255 66. 2(
+33; ?77 883 788< @
+33I P::! (
+33V Y99 ==1 4(
+33q x664 ;88I P>>G N2
+44 66 88 >> DD
+:: == (
+;; #== >>4 ???
+@@ AA
+
+NN '
+NN/ 7PP# +
+PP TT
+RR "TT8 <XX
+UU% &VV
+XX ZZ% &
+ff +
+ 4
+ffB Iii "jj !
+gg0 8mm* 2rrF N
+gg> Gmm qqH Q
+ii mm qq7 =
+jj mm" 'rr6 ;
+kk xx {{
+qq !xx &xx6 A
+rr xx) 3xxD N
+
+ 'PP "$
+
+/ 7
+! )
+1 9
+
+= E
+> F
+
+K T
+H QT
+
+$ +
+
++ 2
+
+5 <
+
+; B0
+
+
+) /
+
+
+
+
+
+
+ %
+
+- 1
+ !$
+
+
+
+
+
+ $
+
+- 4
+
+
+= A
+ $
+
+
+
+ -
+
+
+& '
+
+
+ *
+
+ $0
+
+, 5
+
+
+3 <<
+
+; C
+
+
+" *
+D L0
+
+I R
+
+# ,
+ $
+
+
+
+- 2$
+
+
+
+/ 5$
+
+
+
+ !
+
+
+ #
+
+
+% 00
+
+
+
+& 3
+
+
+ %$
+
+- 1
+! %
+( ,$
+
+7 <
+/ 4
+% *$
+
+B H
+= C
+5 ;
+
+ %
+
+& -
+
+
+
+
+
+
+
+. 5$
+
+
+
+ $$
+
+
+ &
++ 4$
+
+
++ 5
+# -
+
+ -$
+
+5 <
+1 8
+* 1
+
+D J
+
+
+R X
+
+
+ %
+
+
+9 @
+
+
+
+
+
+
+3 :$
+
+
+
+ 0
+
+
+
+
+ 0
+
+
+
+
+ $
+
+
+ "
+, .$
+
+
+
++ -H
+
+
+
+
+
+
+ !
+
+ ,$
+
+4 9
+
+
+
+A G
+
+
+O U
+ T
+
+
+8 :
+
+
+; =
+; =
+& (0
+
+
+3 5
+
+
+, .
+
+ %
+
+
+= D
+
+
+
+
+
+
+6 =<
+
+
+
+
++ 1
+ <
+
+
+
+
+
+ <
+
+
+
+
+
+ $
+
+
+ "
+, .$
+
+
+
++ -`
+
+
+
+
+
+
+ !
+" $
+# %
+
+
+3 ;
+
+
+= F0
+
+ &
+ (
+ %
+ $
+
+. 3
+
+
+
+9 @
+1 8H
+
+
+< >
+
+
+@ B
+ 0
+
+
+3 :
+
+7 >$
+
+
+
+ 0
+
+
+
+3 4
+9 :
+
+ "0
+
+* 1
+
+
+, 30
+
+: B
+
+
+$ ,$
+
+K T
+
+% .0
+
+
+
+0 5
+A F0
+
+
+
+2 8
+ $
+
+
+
+ $
+
+
+ #
+
+
+% 00
+
+
+
+ %
+
\ No newline at end of file
diff --git a/src/src/build/sonar/scanner-report/symbols-26.pb b/src/src/build/sonar/scanner-report/symbols-26.pb
new file mode 100644
index 0000000..ade3dd8
--- /dev/null
+++ b/src/src/build/sonar/scanner-report/symbols-26.pb
@@ -0,0 +1,116 @@
+
+ HH% ,
+ +II
+ PP
+ !LL LL* 6
+ 00
11
22
33
44
88
99
::
;;
<<
[[
\\
]]
^^
__
cc
dd
ee
ff
gg
kk
ll
mm
nn
oo
ss
tt
uu
vv
ww
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ 2JJ '
+
+
+ "%%/ 5
+
+
+
+!! !
+
+"" !
+
+##
+%% ,QQ 'UU #
+
+'' &
+(( ',,3 >
+
+)) &
+
+** &
+,, 0
+ +
+.. 'MM2 A
+//$ 5@@ $MMB S
+77$ ;DD *
+
+?? +
+??0 2@@% '
+
+CC 0
+CC5 7DD+ -
+
+HH $
+HH- 4II: A
+LL #MM %
+NN) *PP= >
+
+YY +
+ZZ$ 6{{ %
+bb$ 7
+ &
+jj$ 5 $
+rr$ 7
+ &
+
+zz +
+zz0 2{{& (
+
+~~ *
+~~/ 1% '
+
+ ,
+
+1 3
+' )
+
+ ,
+
+1 3
+' )
+
+ (
+
+ )
+
+$ 3
+ "
+
+ /
+
+4 6
+# %
+
+$ 3
+ "
+
+ /
+
+4 6
+# %
+
+ /0
+
+$ <
+ .
+ +
+ +
+
+ 2$
+
+7 9
+
+, .
+
+ *
\ No newline at end of file
diff --git a/src/src/build/sonar/scanner-report/symbols-27.pb b/src/src/build/sonar/scanner-report/symbols-27.pb
new file mode 100644
index 0000000..ee2fdc8
--- /dev/null
+++ b/src/src/build/sonar/scanner-report/symbols-27.pb
@@ -0,0 +1,48 @@
+
+ @@/ 7QQ2 :<
+ % ,D K""& -$$" )//& -Z
+ @@ DD GG HH
QQ UU [[ \\
+ VV VV 2
+ " ( 6%% %%( 6
+ AA RR 2
+ ! )## ## )
+
+
+ $EE "YY "
+- 4+ 2
+
+
+ !* 4
+"" %FF $ZZ $
+"". 5##+ 2
+## &&
+
+%% !&&* 4''
+
+// %
+//. 566 "
+00 66 ::
+22 33 !44* /
+33 55
+44 66H N
+77 88
+
+@@ .(
+@@8 @AA EE# +FF% -2
+AA
BB CC DD II
+DD HH! $
+EE HH, 1
+FF HH3 9
+GG HH
+JJ
+
+QQ 12
+QQ; CRR WW YY# +ZZ% -2
+RR
SS TT UU ^^
+UU \\! $
+VV
WWI NXX #
+XX \\) 8]] !
+YY \\: ?
+ZZ \\A G
+[[ \\
+__
\ No newline at end of file
diff --git a/src/src/build/sonar/scanner-report/symbols-28.pb b/src/src/build/sonar/scanner-report/symbols-28.pb
new file mode 100644
index 0000000..c86c463
--- /dev/null
+++ b/src/src/build/sonar/scanner-report/symbols-28.pb
@@ -0,0 +1,91 @@
+
+ ..( 0"
+
+
+) 4
+ \\: A.
+ &
+ '
+
+ )
+' 6..< K
+' 8..M ^D
+ CC
+
+$ *
+! '
+ &
+ !ff' 3ii' 3
+ 22 QQ !
+ $aa !aaD S
+ aa
+ 55 "
+ \\ \\ '
+ cc (dd F
+!! MM RR ss ww {{
+"" 77 #99 <
+## !:: "== &>> #?? #@@ #8
+%% IIE F
+
+! "
+% &
+&& "SSK P
+'' &GG SS
+)) || F
+++* -MM RR ss ww {{
+
+..
4
+// FF GGK RSSB I
+2 9H
+00 GG HH HH HHB JJJ
+ "
+11 1HH+ ?II (
+22 QQ gg ii ll mm nn oo
+
+
+
+
+
+55
+55# 566 )
+99 :: ==
+CC FF# )
+KK* +MM& '
+[[ <<
+
+\\ ]]
+`` UU
+aa ll( +
+cc ff
gg' 8
+pp* +ss, -
+tt# $ww, -
+xx' ({{, -
+|| , -
+
+ !TT H
+
+ "
+
+
+
+
+
+
+
+
+( .
+
+4 9
+ 0
+
+
+
+
+ $
+
+
+
+* 0
+
+
+
\ No newline at end of file
diff --git a/src/src/build/sonar/scanner-report/symbols-29.pb b/src/src/build/sonar/scanner-report/symbols-29.pb
new file mode 100644
index 0000000..90d220b
--- /dev/null
+++ b/src/src/build/sonar/scanner-report/symbols-29.pb
@@ -0,0 +1,26 @@
+(
+ 99 991 =;;% 1
+ 88 !882 ?
+ (' 8
+ "77# .
+ ** !::. 5(
+ **+ 166 66( .
+ ,, (
+ ",,6 ;..P U77> C2
+# ."" ## .. ..7 B
+
+
+!!# ---
+&& &77` i
+'' 055/ B
+
+** 2
+**" ),, 66/ 688M T99? F
+
+**2 8
+++
//. 9F
+,, 22
33 55% &77V W<< >>
+55 ";;> G
+66 !77 88Y _
+88" /;;I V
+99! -;;
\ No newline at end of file
diff --git a/src/src/build/sonar/scanner-report/symbols-30.pb b/src/src/build/sonar/scanner-report/symbols-30.pb
new file mode 100644
index 0000000..a0cff15
--- /dev/null
+++ b/src/src/build/sonar/scanner-report/symbols-30.pb
@@ -0,0 +1,10 @@
+
+ (# 4
+ !
+ + 1
+
+
+
+
+" ) (
+2 8 $
\ No newline at end of file
diff --git a/src/src/build/sonar/scanner-report/symbols-31.pb b/src/src/build/sonar/scanner-report/symbols-31.pb
new file mode 100644
index 0000000..aee75e3
--- /dev/null
+++ b/src/src/build/sonar/scanner-report/symbols-31.pb
@@ -0,0 +1,475 @@
+
+ "
+& 7
+ 55 FF PP PP #TT $XX $cc $gg $ll oo' /pp( 0qq& .
+ "
+
+ "
+ "
+
+
+
+ '
+7 ?
+P X
+
+7 ?
+ !
+
+ !
+
+ !
+
+ !
+
+ !
+
+
+
+
+
+ (
+. 6F
+
+
+3 4
+3 4
+6 7
+3 4.
+
+ !
+ !
+ !"
+ %
+ &
+- 7:
+
+2 6
+> B
+' +
+' +
+ !$ /
+ "11 22 33 44 CC CCL XEE" .LL LLL XNN" .vv vvN Zxx" .
+
+L X
+" .
+ $
+ $
+ '
+ $
+
+ -
+!!! 5==! 5
+## .RR( 9RRK \VV. ?VVM ^[[ /[[A R\\" 3\\A Rkk4 EkkU f
+ 0
+1 B
+0 A
+) :
+ (
+ /
+# 4
+ .
+ 1
+! 2
+ 1
+$$ -aa .ee4 DB
+%% -''4 D775 E
+' 7
+ ,
+ .
+&& 1
+! 5
+'' 1
+! 5
+(( >
+% F
+)) >
+% F
+** >
+% F
+++ >
+% F
+,, 2
+# 8
+-- 2
+# 8
+.. 1
+! 5
+// 1
+! 5v
+11 +
+
+
+
+
+
+
+
+
+
+22 +kk &
+
+
+
+
+
+
+
+
+ r
+33 -yy )zz )
+
+
+
+
+
+
+
+44 +
+
+
+
+
+
+
+
+
+
+
+55 FF SS( -WW( -bb( -ff( -ll
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ !"
+77 '
+
+( :
+99 RR VV ]] ]] "kkI N
+
+
+
+
+
+
+
+
+ h
+;; !QQ
+
+
+
+
+
+
+ .
+==
+
+
+ ^
+?? !
+
+
+
+
+
+
+
.
+AA& @
+ "
+ &
+ &
+CC/ E
+/ E
+
+EE !
+
+EE/ 5
+EE; AFF5 ;
+EEG MFF, 2
+LL/ E
+/ E
+
+NN !
+
+NN/ 5F
+NN; ARR $VV$ *[[ \\ aa ee !F
+NNG MRRA GVVC I[[7 =\\7 =aa6 <ee* 0<
+OO !UU !YY !dd !hh !nn x
+PP SS TT WW XX bb cc ff gg oo "pp #qq !
+kk ll, 3
+vv/ G
+1 I
+
+xx !
+
+xx/ 5
+xx; A|| ~~ *
+xxG M||& ,~~- 3
+' -
+yy ||0 8~~! )
+zz || "~~7 ?6
+{{ }}
+
+0 6
+
+
+
+
+/ E
+/ E
+
+ !
+
+/ 5
+
+; A
+
+G M"
+
+ .AA %
+- F
+
+
+' 8
+
+. 2
+
+8 <
+
+B G
+
+
+
+$ -
+
+3 9
+
+
+
+" )
+
+
+
+ $
+
+" )
+
+6 =
+
+0 4
+
+
+
+ $
+
+" )
+
+
+
+0 4
+
+
+> J
+ "
+
+
+( 6
+
+
+ `
+
+# *
+ !
+
+ '
+" )
+ '
+ '
+
+
+
+
+
+ *
+
+
+
+
+$ (
+ T
+
+
+
+
+/ 2
+H K
+
+/ 2
+
+
+
+
+# '
+
+
+- 2
+
+
+
+
+
+ )
+
+
+/ 5
+ $
+
+
+& 4
+? M"
+
+ oo
+ $
+
+# '
+ "
+! %$
+
+
+' 6
+ #"
+
+ pp
+ $
+
+$ )
+ #
+" '$
+
+
+, 9
+' 4"
+
+ qq
+ $
+
+" ,
+ (
+) 3`
+
+ "
+ 1
+ #
+ &
+ *
++ >
+ &
+8 K
+
+
+& 4<
+
+
+
+
+
+7 ;$
+
+
+
+ l
+
+# ,
+ '
+( 1
+
+
+
+
+
+ '$
+
+
+( 8
+O _
+
+
+ 0
+
+% +
+ $
+ &
+# )
+
+
+
+
+ 0
+
+& 2
+ )
+ $
+# /
+
+
+ R
+
+ "GG
+ !
+
+
+
+ <
+
+
+
+
+
+M P0
+
+
+
+0 1
+ ^
+
+ "^^ %
+ %
+ %
+
+
+
+
+
+
+" '$
+
+ "
+
+
+
+ ,
+
+G O
+% -t
+
+ "HH mm
+
+
+
+
+
+
+
\ No newline at end of file
diff --git a/src/src/build/sonar/scanner-report/symbols-32.pb b/src/src/build/sonar/scanner-report/symbols-32.pb
new file mode 100644
index 0000000..6c7e376
--- /dev/null
+++ b/src/src/build/sonar/scanner-report/symbols-32.pb
@@ -0,0 +1,50 @@
+Z
+ "" "" %22 "33 "44 "55 "66 ";;
+ ==$ %>>% &(
+ )%% -- ,00* 8
+* C//9 R
+ * 5(( &
+ ++ '
+ &TT '
+' 6 A P>>H W
+ %?? F
+ $MM NN OO PP )PP: CQQ
+
+
!x
+"" 22 33 44 55 66 77 !::
;;
<<' ,@@ VV7 <
+## !DD PP (
+$$" 8HH UU "VV "2
+%% *-- .. // <<
+'' *$$ !GG) >
+((
VV# 0
+
+((' -
+
+((4 8
+
+++ 2
+++( /,, --- 4== >>
+++6 ::: "
+
+00 )
+
+009 =
+00C G22) -
+00M R33* /
+11 "441 ;
+11( 1550 9
+117 =66+ 1
+CC ??
+CC& 2DD $
+
+GG (
+GG? GHH! )
+KK 77 @@
+KK" &QQ= A
+LL PP QQC G
+
+TT
+
+TT( ,
+
+TT2 6
\ No newline at end of file
diff --git a/src/src/build/sonar/scanner-report/symbols-33.pb b/src/src/build/sonar/scanner-report/symbols-33.pb
new file mode 100644
index 0000000..01c45d0
--- /dev/null
+++ b/src/src/build/sonar/scanner-report/symbols-33.pb
@@ -0,0 +1,33 @@
+
+ ##
+ !!
+ 66
+ ** $
+ ())' 6
+ ##) /
+ && "
+ 7003 J
+ %%& '
+
+
<
+ $$ %% &&, 3)) ;; F
+ && '' (( ++ 11 22 (
+!! ''
((5 :77
+
+##
+## '&&# *
+##0 6$$
+##< B((- 3
+
+**
+
+**% &
+
+00 2
+00K S222 :
+
+66
+66! #77
+
+::
+::& +;;
\ No newline at end of file
diff --git a/src/src/build/sonar/scanner-report/symbols-34.pb b/src/src/build/sonar/scanner-report/symbols-34.pb
new file mode 100644
index 0000000..ba66cf0
--- /dev/null
+++ b/src/src/build/sonar/scanner-report/symbols-34.pb
@@ -0,0 +1,45 @@
+<
+ )) %// 44$ +<< 'EE %<
+ ))/ 5//) /445 ;== ==
+ // 44
+ //8 A
+ # ( 5
+ "BB) 5
+ CC HH 2
+ 77 ?? GG HH, -
+ "66> C>>- 2
+# ."" ##
+
+
+
+!!" ,
+&& %660 9>> (
+'' '77T _??P [
+
+))
+))& -**
+))6 7**
+
+//
+// '00" )
+
+//0 6
+
+//B H
+
+44
+44 "55 88 "
+44, 366V ]
+44< B66! '77C I
+66 88) 3
+
+<<
+<<( />>E L
+<<5 ===) 1
+== >> ??? E(
+BB 00 !55 *88
+CC HH LL
+EE 00 !
+EE& -FF GG
+KK 88$ (
+KK $LL
\ No newline at end of file
diff --git a/src/src/build/sonar/scanner-report/symbols-35.pb b/src/src/build/sonar/scanner-report/symbols-35.pb
new file mode 100644
index 0000000..67e9b2b
--- /dev/null
+++ b/src/src/build/sonar/scanner-report/symbols-35.pb
@@ -0,0 +1,52 @@
+
+ --L T
+ $ ,
+ GG
+ &HH4 CKK0 ?
+ (!! MM 1
+ 44X _
+ 'RR@ P\\@ P
+
+
+ %RR$ 2\\$ 22
+ ) // %222 D44+ =
+ EE
+
00 %
+ %% "
+ ##
+ DD DD& /(
+ ! 99 %??" -2
+ 77 &;;8 B==1 ;2
+ @@ @@c h[[$ )[[X ]
+ '-- F
+ (( //4 5559 :77? @99> ?DDI J(
+
--* 8GG( 6[[3 A
+ 77 ;; d
+ 99 ?? @@Q WNN2 8OO5 ;TT: @YY5 ;^^; A``: @2
+ &// 00 11 22 <
+!!% +** OO$ *PP$ *YY$ *ZZ$ *F
+## 55 77' 199& 0??/ 9DD1 ;GGE O
+
+%%
+%%# 5&& )
+
+44 *
+
+44> P(
+44` gEE 'TTW ^``W ^
+
+== 0
+
+==< A
+==G P??G P
+DD "FF
+EE FF( .
+
+KK( /
+
+KK@ O
+
+KKU V
+MM2 6NN# '
+RR3 =TT$ .VV$ .(
+\\3 =^^$ .``$ .aa$ .
\ No newline at end of file
diff --git a/src/src/build/sonar/scanner-report/symbols-36.pb b/src/src/build/sonar/scanner-report/symbols-36.pb
new file mode 100644
index 0000000..4d62940
--- /dev/null
+++ b/src/src/build/sonar/scanner-report/symbols-36.pb
@@ -0,0 +1,72 @@
+
+ mm mm
+ $tt &
+ nn pp *2
+ && ((- .**E F[[E F
+ %
+ ww ww !<
+
+
+ ** ,, [[ rr &
+ %** %[[ %
+ 22 Z
+
#* /5 :B GL QW \d io t
+ 44& ,]]& ,2
+ .. \\
\\
+ $$ "
+ ll &2
+ ::+ 6>> $CC $NN $F
+ 88) -::# 'ZZ `` ee jj
+ ((
+ ss ss) .
+
+
2
+ (( 55 88 JJ !<
+ ,, 22 &55! +JJ1 ;rr P
+ ..
//
00
440 5HH> Caa
ff
2
+ 22 44 HH ]] (
+ @@ HH( .KK (
+ AA HH0 6LL
+ 00 aa
+ aa# -
+ // $ff $
+!! //% .ff) 2
+
+$$
+$$# 5%% )2
+** ,,) /,,< B,,P V44
+
+:: "
+
+::( )P
+::7 <<< "@@! &AA! &EE" 'FF" 'PP$ )QQ$ )
+<< ==
+EE HH8 9KK! "
+FF HH; <LL! "
+
+PP !
+
+QQ !
+
+ZZ
+
+ZZ $
+[[ ]]
+\\ ]]0 5
+
+``
+
+``! %
+
+ee
+
+ee
+
+jj
+
+jj
+ll mm &xx% .
+mm
pp+ /
+nn pp rr@ G
+tt' (uu
+ww xx yy #
\ No newline at end of file
diff --git a/src/src/build/sonar/scanner-report/symbols-37.pb b/src/src/build/sonar/scanner-report/symbols-37.pb
new file mode 100644
index 0000000..70d1488
--- /dev/null
+++ b/src/src/build/sonar/scanner-report/symbols-37.pb
@@ -0,0 +1,1928 @@
+R
+
+N V
+N V
+ N V
+ N V
+
+
+N V
+
+
+N VR
+
+
+
+
+
+
+
+
+
+
+
+
+ ^
+ %
+ %
+
+ , 9
+ %
+ !
+ 8 E
+ $ 1
+
+ "
+
+
+ "
+
+
+ "
+ "
+% /
+D N
+ ii& ..
+
+
+* 6
+! -F
+
+
+2 =
+& 1
+
+0 ;
+
+ "
+
+
+* 7:
+
+ -
+; H
+3 @
+7 D.
+ )
+ $
+# 3
+ (
+!! "
+ &.
+""
+
+V ]
+V ]:
+## &
+ +
+0 ?
+? N
+ /
+$$
+I O
+
+ &
+' -
+ "
+I O
+& ,
+ #
+& ,
+
+" (
+$ *
+7 =
+$ *
+ %
+
+
+ "
+
+ "
+# )
+
+
+ "
+
+
+ &
+
+ &
+
+( .
+% +
+$ *
+ "
+ "
+ "
+
+
+ $
+% +
+E K
+
+ $
+ ! '
+
+
+
+
+
+ $
+%% (
+
+&&
+ R
+''
+> C
+' ,
+? D
+6 ;
+ $
+7 <.
+((
+ "
+* 0
+' -
+)) +
+ (:
+**
+) 1
+
+) 1
+ .
+++
+
+ !
+ = F
+,, #
+
+( 7
+ '
+ 1 @
+ '
+ 1 @
+
+
+
+ ! 0
+ ' 6
+
+ , ;
+--
+ 3 :
+..
+
+
+
+
+
+
+
+
+3 <
+
+ "
+//
+/ :
+) 4^
+00 $
+- 6
+0 9
+ #
+: C
+ #
+6 ?
+; D
+11 -
+ /F
+22 #
+
+ " +
+ $ -
+
+ . 7
+33
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ "
+44 "
+ "
+ "
+55
+( ,
+66
+) 1"
+77
+& 1
+- 8
+88
+
+
+
+
+H L
+8 <
+8 <
+8 <
+8 <
+4 8
+/ 3
+1 5
+, 0
+" &
+
+
+/ 3
+a e
+
+/ 3
+S W
+S W
+, 0
+4 8
+/ 3
+8 <
+, 0
+
+0 4
+W [
+
+" &
+$ (
+
+
+Z ^
+Z ^
+( ,
+& *
+
+ #
+
+ $
+ & *
+99 (ii: I
+( 7:
+:: !
+ !
+ +
+ !
+ +F
+;; 2
+
+1 C
+/ A
+
+1 C"
+<<
+
+! '.
+==
+
+
+ "
+>> $
+) 7
+??% <
+* AR
+@@
+
+
+
+ (
+
+! )N
+AA pp tt
+) 2
+* 3
+
+ %"
+BB "
+
+ %N
+CC nn rr
+
+( 0
+) 1
+
+DD
+
+Q V
+
+
+
+G L
+
+ G L
+
+ @ E
+
+ V ["
+FF &
+
+ R
+GG '
+
+
+
+
+
+
+
+
+
+
+II zz {{ || }} ~~
+; <
+8 9
+9 :
+: ;
+: ;
+
+
+
+
+A B
+A B
+B C
+A B
+
+4 5
+4 5
+4 5
+
+6 7
+& '
+? @
+A B
+@ A
+B C
+. /
+( )
+, -
++ ,
+) *
+4 5
+
+& '
+& '
+
+
+
+8 9
+
+8 9
+
+
+
+
+
+
+
+
+
++ ,
+- .
+
+
+
+
+
+
+
+E F
+
+
+= >
+E F
+5 6
+ !
+6 7
+C D
+4 5
+9 :
+9 :
+E F
+6 7
+B C
+
+
+6 7
+< =
+= >
+JJ "
+L Q
+0 5
+. 3
+0 5
+
+- 2
+0 5
+, 1
+3 8
+* /
+
+
+L Q
+6 ;v
+KK# +
+/ 7
+3 ;
+/ 7
+/ 7
+
+
+/ 7
+ $
+ "
+LL 0
+
+/ BF
+MM )
+
+ *
+# .
+# .
+ *
+NN* Djj ":
+OO &
+
+ '
+
+ "
+PP '
+
+ '
+QQ +zz2 @{{/ =||0 >}}1 ?~~1 ?
+$ 2
+$ 2
+$ 2
+$ 2
+$ 2
+1 ?
+1 ?
+2 @
+1 ?
+& 4
+& 4
+& 4
+& 4
+ "
+@ N
+ (:
+RR, C
+, C
+ 2
+ /
+% <"
+SS (
+
+ '
+TT0 E
+' <
+UU( @jj$ <
+VV 4
+" 7
+WW 4
+" 7"
+YY
+@ N
+X f:
+ZZ
+
+ #
+
+
+
+
+
+
+[[ $
+
+
+ &"
+\\
+
+
+
+
+
+ &:
+]]
+
+
+
+
+
+, 7
+^^
+ "
+__
+
+) :8
+`` wwH O
+M T
+F M
+O V"
+aa
+
+$ +8
+bb ww
+
+
+ "
+cc
+
+ :
+dd
+
+
+
+
+ee
+ ( ,"
+ff
+
+ #
+ii
+) 9
+5 E
+* :
+* :
+# 3
+ # 3
+ /
+ +
+ / ?
+ 7 G
+ 8 H
+ * :
+ * :
+
+
+* :
+
+
+* :"
+mm
+
+ ."
+nn "
+ $
+ $.
+pp $
+ )
+ )
+ %F
+rr #
+" -
+" -
+ )
+ )
+ %"
+tt %
+ &
+ &`
+ww/ Azz {{ || }} ~~
+ (
+ %
+& 8
+
+/ F
+
+
+
+
+
+ 1
+ 0
+ 0
+ 0
+ ,`
+
+/ ?
+
+
+
+
+ &
+ #
+ *`
+
+/ H
+ !
+ !
+ !
+ !
+ 2
+ 2
+ 6H
+
+
+
+
+G J
+6 9
+A D
+
+ #
+
+
+
+
+
+ !
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ ,
+
+ !
+ !
+
+
+
+
+
+
+
+
+
+ 0
+
+
+
+
+ l
+
+ %
+
+" 6
+
+
+
+
+
+ l
+
+ "
+
+" 3
+
+
+
+ $
+
+ !
+
+
+
++ 6
+ #
+
+
+
+
+% 0
+
+
+
+
+ (
+
+
+( 3
+ !
+
+
+
+
+
+
+ 0
+
+ !
+
+
+
+
+ $
+< H
+
+
+
+
+ $
+
+
+
+
+
+ )
+8 D
+- 9
+/ ;
+
+
+ #
+ $
+
++ 7
+. :
+
+
+
+5 A
+5 A
+
+
+! -
+1 =
+/ ;
+- 9
+
+
+
+
+
+. :
+ )
+
+
+6 B
+
+ "
+
+
+
+N Z
+
+, 8
+8 D
+
+
+
+ $
+
+
+6 B
+* 6
+
+
+2 >
+
+
+& 2
+
+ & 20
+
+ *
+
+ "
+
+
+
+* 5
+
+
+
+7 B
+
+= H
+7 B
+I T
+; F
+V a$
+
+ 4
+* >
+' ;$
+
+ 8
+" =
+ +<
+
+ *
+ '
+" -
+" -
+" -H
+
+ ,
+# 0
+" /
+N [
+" /
+" /
+
+ &
+
+ &
+ )
+
+" /
+" /
+ !
+
+$ 1
+ )
+
+
+
+
+
+ "
+
+
+
+ -
+ )H
+
+
+
+
+S ]
+3 =
+S ]$
+
+
+
+ 0
+
+
+
+
+ <
+
+ "
+ S b
+
+ ; J
+
+
+3 B
+
+ $
+
+# 5
+ )
+
+
+
+ *
+
+% ,
+5 <
+
+ !
+
+
+
+ +
+
+
+ +
+
+
+ +
+
+
+
+
+
+4 9
+
+
+
+4 9
+; @
+
+
+
+4 9
+; @
+ <
+
+
+
+ $
+; @
+ %
+
+
+
0
+
+
+, 9
+
+, 9
+
+ )
+
+7 8
+
+> C
+
+I N
+
+T Y
+
+ %
+
+3 4
+
+: ?
+
+E K
+
+Q V
+
+ (
+
+2 3
+
+
+ `
+
+
+
+
+
+
+; =
+
+ $
+
+
+
+ $
+
+
+
+
+
+ "
+g j
+
+O Q
+ $
+
+
+" %
+ $
+
+
+
+" %
+
+
+
+
+! "
+- .
+
+
+
+
+
+ )<
+
+1 C
+% 7
+
+* <
+. @$
+
+
+
+# )0
+
+ %
++ <
+ "
+
+
+- 3
+1 7
+
+
+% +
+ #
+B H
+ "
+ !
+ #
+
+! '
+ "
+: @
+! '
+
+
+ "$
+
+
+E M
+A I$
+
+
+O W
+K S$
+
+
+ &
+U _$
+
+
+( /
+ <
+
+
+! ,
+& 1
+ #
+3 >0
+
+
+
+% -
+@ H0
+
+
+
+: @
+J P
+
+
+ )
+
+ (
+
+
+
+
+
+
+5 7$
+
+
+
+ $
+
+
+
+5 9
+
+ $
+
+& ,
+
+
+
+ &$
+
+. 6
+" *
+
+
+ %0
+
+2 4
+8 :
+5 7
+( *$
+
+ !
+ !
+ !0
+
+' +
+
+$ (
+$ (<
+
+9 ;
+
+
+
+ 0
+
+
+! )
+
+ $
+
+
+
+ !$
+
+
+
+ !
+
+
+
+
+
+4 6
+
+
+
+
+
+% '
+
+
+
+
+
+ H
+
+
+
+
+
+
+ #
+
+
+
+
+ H
+
+
+
+2 4
+= ?
+0 2
+/ 1
+
+ 0
+
+ %
+
+
+
+
+ (
+
+ 'x
+
+- 1
+
+= A
+8 <
+
+
+
+
+
+
+
+ (
+
+2 6
+ T
+
+$ +
+
+
+
+
+
+
+
+( /
+
+@ F
+
+L Q
+
+
+ $
+
+
+
+
+
+ %
+
+2 8
+
+? C
+* .
+
+
+
+
+ '
+
+
+0 4
++ /0
+
+
+
+
+ $
+
+
+ <
+
+
+
+
+
+
+
+ "
+ 10
+
+
+
+F I
+G J$
+
+
+
+
+
+
+
+
+ #
+
+) -
+: >
+
+7 :
+ $
+
+
+
+N T$
+
+ '
+$ 1
+@ M$
+
+ %
+
+
+
+
+
+ <
+
+% *
+
+# (
+
+; @
+
+3 7
+ $
+
+
+
+$ .<
+
+
+ !
+0 1
+5 6
+ T
+
+
+
+
+
+
+
+
+
+
+
+
+ <
+
+$ )
+
+& +
+$ )
+
+
+2 6
+ $$
+
+
+ "
++ /$
+
+
+
+ <
+
+
+ !
+C D
+5 6
+ 0
+
+ !
+
+
+
+
+) -
+
+
+
+ <
+
+
+8 =
+
+. 3
+! &$
+
+
+# '
+2 60
+
+ -
+ 7
+ ,
+ 70
+
+5 =
+8 @
+P X
+) 1$
+
+F O
+ (
+' 0$
+
+ !
+
+ <
+
+
+
+@ A
+K L
+ $
+
+
+
+ 0
+
+
+
+& 1
+ )x
+
+$ (
+
+
+
+8 <
+
+
+
+: >
+- 1
+
+. 3
+ 0
+
+
+1 5
+" &
+
+
+
+
+
+' +
+
+
+ #
+
+
+
+ 0
+
+
+
+
+
+
+
+ (
+
+8 B
+
+L U
+
+
+ 0
+
+! &
+
+% *
+% *
+
+0 7
+
+
+ &
+
++ 2
+
+8 ?
+ <
+
+ "
+
+
+
+ $
+
+
+ "
+ 0
+
+
+
+
+( *0
+
+
+
+? @
+5 6$
+
+
+3 7
+$ (0
+
+ !
+' +
+B F
+D Hl
+
+
+
+
+
+
+
+
+
+ $
+
+
+
+
+
+
+ T
+
+
+
+
+
+
+
+ 0
+
+ !
+
+
+: H
+
+ (
+ )`
+
+0 7
+
+
+
+
+
+@ G
+/ 6<
+
+
+
+
+
+
+
+ $
+
+
+
+
+
+ $
+ "
+
+* 2
+$ ,
+
+
+ $
+
+ -
+
+ $
+
+
+
+
+
+$ (
+3 7
+
+ -
+
+
+
+ 0
+
+" )
+
+
+ %0
+
+
+* .
++ /
+. 2T
+
+
+ #
+ #
+" '
+ #
+
+& +
+
+
+ $
+
+
+
+0 6
+
+< A$
+
+
+) /
+ <
+
+
+
+
+
+
+
+
+
+% &$
+
+
+' /
+) 1$
+
+
+E I
+2 6
+
+ )
+
+7 8
+
+> C
+
+I N
+
+T Y
+
+ %
+
+3 4
+
+: ?
+
+E K
+
+Q V
+
+ (
+
+2 3
+
+
+
+
+
+ $
+
+
+
+ '
+
+ #
+
+( 3
+ $
+
+9 C
+ !
+ "0
+
+L P
+& *
+ ( ,
+ 9 =
+
+ #
+? J
+
+ !
+L P0
+
+ !
+' -
+
+" (
+
+ $
+3 ?
+
+
+ "
+
+# $
+
+
+ &
+ A H
+
+ ( *
+ . 0
+
+ ' (
+
+
+ &
+ A H
+
+ ( *
+ . 0
+
+ " #
+
+
+
+ <
+
+ " &
+ ) -
+ 1 5
+ / 3
+ ! %$
+
+
+ 5 <
+ / 6
+
+
+
+
+
+ " $
+
+ )
+ ! .
+
+ 1 5
+ 1 5$
+
+ > E
+ 1 8
+ ! ($
+
+
+
+
+ $
+
+
+ / 4
+ < A
+
+ %
+ 7 >H
+
+
+
+ & ,
+
+ & ,
+ 2 8
+
+
+ 0
+
+ &
+ -
+ -
+ !H
+
+ 7 9
+
+
+
+
+
+ ) +H
+
+
+ " $
+
+
+ $ &
+ <
+
+
+
+
+
+ ! &0
+
+
+
+ !
+ !0
+
+
+
+ " '
+ < A
+
+
+ <
+
+
+
+
+
+ $
+
+ %
+
+ )
+
+
+
+
+
+ 1 6
+
+
+ 8 ;
+
+
+ = A$
+
+
+ ; @
+ H M
+
+ * 1
+ C JH
+
+ !
+
+ 2 8
+ "
+ 2 8
+ O U
+
+ '
+ & /
+
+ # $
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ '
+
+
+ '
+
+ ( ,
+
+
+ "
+
+
+
+
+
+
+ <
+
+
+
+
+
+
+
+
+
+: =
+
+
+
+
+
+
+
+
+
+
+
+
+' +
+
+
+
+> ?
+
+
+
+
+
+
+8 9
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ '
\ No newline at end of file
diff --git a/src/src/build/sonar/scanner-report/symbols-38.pb b/src/src/build/sonar/scanner-report/symbols-38.pb
new file mode 100644
index 0000000..f682992
--- /dev/null
+++ b/src/src/build/sonar/scanner-report/symbols-38.pb
@@ -0,0 +1,186 @@
+(
+ PP ]] aa
+
+B F
+ rr
+ uu "
+
+! (
+% ,
+
+ %"
+ !
+
+L S
+ ]]) 5aa) 5"
+
+
+
+
+' 2P
+ * 2
+
+
+( 0
+
+
+
+; C
+ 4
+ 3
+ gg +ii
+
+!! 4
+## 33, -44- .55. /
+# $
+%% 11H O
+&& 11
+((
+0 <"
+)) #
+
+ Z
+** RR VV
+< B
+C I
+> D
+7 =
+7 ="
+++ +
+ +
+ 8
+-- *33 *
+.. +44 +
+// ,55 ,@
+11. A33 44 55
+# 6
+' :
+;; -NN $YY, D
+@@
+2 B
+
+@@" '
+
+@@0 4
+FF
+. =
+
+FF! &
+
+FF/ 3"
+KK
+* 6
+* 6
+
+KK #
+
+KK- 4t
+NN% >ZZ !
+ -
+ -
+ 1
+ -
+ -
+ %
+ )
+ )
+
+PP
+PP 'QQ
+
+UU
+UU "VV
+
+YY +
+YYE MZZ$ ,
+
+]]
+]] '^^
+]]6 ;^^
+
+aa
+aa 'bb
+aa6 ;bb
+aaA Ibb &
+
+gg 2
+gg, 1hh kk #ll #{{" '(
+kk mm oo tt> ?(
+ll nn pp ss5 6
+rr ss !tt
+ss tt8 <
+tt uu2 5
+
+ "
+! (
+
+ &
+3 8
+( -
+
+ $
+
+ &
+
+ $
+
+1 6
+& +$
+
+ &
+8 F
+5 C
+
+
+J N
+
+ !$
+
+* 1
+
+ $
+
+7 @
+& /
+
+G \
+1 F
+
+ &$
+
+3 7
+
+" &$
+
+
+ '
+ '$
+
+
+) /
+) /
+
+
+B E
+
+
+G J0
+
+
+
+
+ $<
+
+
+ $
+
+
+" .$
+
+ !
+0 6
+? E
+
++ :
+
+D H
\ No newline at end of file
diff --git a/src/src/build/sonar/scanner-report/symbols-39.pb b/src/src/build/sonar/scanner-report/symbols-39.pb
new file mode 100644
index 0000000..0061731
--- /dev/null
+++ b/src/src/build/sonar/scanner-report/symbols-39.pb
@@ -0,0 +1,152 @@
+
+ VV *
+ VV) /zz $
+" (
+ kk
+= F
+ $ll D
+ "ii
+
+2 7
+9 >
+ "
+# . !! "" ## $$ %% && '' (( )) ** ++ ,, --
+
+ "
+ &jj $
+
+
+
+ %
+00 &WW &
+11 0XX$ 7
+22 /YY# 5
+33 0ZZ& 9
+44 2[[( =
+55 1\\' ;
+66 /]]$ 6
+77 -^^# 3
+88 +__$ 28
+99 (bb )
+" -
+) 4
+ (
+:: -cc" 2
+;; /dd$ 6
+<< %ee% -
+== !ff! %*
+?? WW jjY \
+ ,
+@@ XX
+
+
+AA YY
+
+BB ZZ
+
+CC "[[
+
+DD \\
+
+EE ]]
+ B
+FF ^^ ii
+
+
+ 4
+GG __ `` ``
+ ,
+HH bb
+
+
+II cc
+
+JJ dd
+ H
+KK ll mm nn ss tt
+ H
+LL hh jj kk# /ll4 @nn (
+O [
+MM ee
+
+NN ff
+
+PP {{
+ ,
+QQ ||
+) 5
+
+RR "}}
+ ,
+SS - !
+ 1
+ (,
+TT 0~~ $
+ 4
+ +
+
+VV
+VV 'jj; Bll+ 2
+VV0 6WW XX YY ZZ [[ \\ ]] ^^ __ bb cc dd ee ff ww
+zz ww p
+zz% +{{ || }}
+ !
+
+
+ !
+
+
+
+
+- 5
+
+
+
+
+
+ '
+
+ )
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ !
+
+) /
+
\ No newline at end of file
diff --git a/src/src/build/sonar/scanner-report/symbols-4.pb b/src/src/build/sonar/scanner-report/symbols-4.pb
new file mode 100644
index 0000000..848fbb9
--- /dev/null
+++ b/src/src/build/sonar/scanner-report/symbols-4.pb
@@ -0,0 +1,21 @@
+
+ ''$ +
+ 22 (
+9 > O T!!* /44 %(
+) -!! "" 33
+ )11
+ ?? EE
+ )) '
+
+
<
++ 8(( )) ,, -- <<
+ #?? EE
+ 300 .
+
+'' #
+'', 322 F
+''< G,,% 0--% 0114 ?66 *<<" -EE; F
+00 55 2
+22 99 99 $;; $BB
+;; <</ 3==
+>>/ 0??9 :
\ No newline at end of file
diff --git a/src/src/build/sonar/scanner-report/symbols-40.pb b/src/src/build/sonar/scanner-report/symbols-40.pb
new file mode 100644
index 0000000..acff895
--- /dev/null
+++ b/src/src/build/sonar/scanner-report/symbols-40.pb
@@ -0,0 +1,1710 @@
+
+
+O W"
+ &
+
+
+ #
+
+ aa' /
+
+
+
+
+6 A
+
+* 5
+
+0 ;
+
+2 =
+
+/ :
+
+6 A
+
+6 A
+
+6 A
+
+ 4 ?"
+
+
+ F
+ )
+ $
+/ ?
+' 7
+# 3
+ (
+ (
+7 H"
+ &
+
+& 5:
+ $
+ %
+3 @
+ !
+/ <"
+
+V ]
+V ]
+ &
+ /
+4 C
+( 7
+ /
+? N
+ /
+ +
+0 ?
+) 8
+ /
+ C R
+ ( 7
+
+E K
+
+ "
+
+
+ "
+
+
+
+ "
+
+ "
+
+ "
+ (
+ .
+!!
+% +
+A G
+$ *
+"" -
+
+##
+' ."
+$$ '
+ &
+ &
+%% %
+ :
+&& )
+
+ .
+4 F
+' 9"
+'' !
+
+ "
+((
+
+
+))
+
+**
+ "
+++ +
+ 0"
+,,
+) 1
+ 1 9j
+--
+ "
+ %
+
+
+ !
+ &
+
+ %"
+..
+* 5
+ 1 <
+//
+
+
+
+$ '
+
+
+
+
+
+
+
+
+
+
+
+
+ R
+00
+
+* 4
++ 5
++ 5
+( 2
+. 8
+11
+( 3
+22 /
+B Q
+33
+ .
+44 #
+
+ .
+- <
+55 +
+ 9 P:
+66 "
+% 3
+ ,
+ "
+ &:
+77
+; ?
+< @
+$ (
+( ,^
+88
+
+/ 7
+
+< D
+' /
+) 1
+) 1
+99 4
+L c
+::
++ 6
+ )
+ +
+% 0
+ +
+0 ;
+ +
+ *
+/ :
+' 2
+
+
+;;
+# '
++ /
+* .
+/ 3
+. 2
+& *
+
+& *
+ #
+
+& *
+ $
+
+ #
+
+ $
+( ,
+* .
+( ,
+: >
+7 ;
+
+ ( ,
+ : >,
+<< (aa; J
+( 7
+ 0 ?"
+== 4
+ -
+W r"
+>> (
+. =
+4 CF
+?? 2
+
+1 C
+/ A
+
+1 C"
+@@ !
+ +
+ # .
+AA" 5
+5 H
+BB" 9aaL c^
+CC
+
+
+
+
+! '
+
+ ) /:
+DD
+
+! )
+
+ $ ,,
+EE ~~
+ "
+* 2
+FF
+A J.
+GG
+
+
+
+HH
+
+B G
+
+B G
+
+B G
+
+B G
+
+F K
+
+? D
+
+
+
+M R
+
+
+
+ !
+
+@ E
+
+? D
+
+A F
+
+0 5
+ %
+ N S
+JJ '
+
+LL
+
+O P
+4 5
+1 2
+G H
+, -
+, -
+= >
+' (
+& '
+
+& '
+
+5 6
+
+5 6
+3 4
+" #
+" #
+A B
+
+/ 0
+1 2
+
+
+" #
+
+
+6 7
+= >
++ ,
+, -
+E F
+1 2
+3 4
+8 9
++ ,
+- .
+& '
+
+3 4
+O P
+
+
+& '
+& '
+
+
+
+
+
+
+D E
+
+
+
+' (
+' (
+' (
+
+' (
+' (
+ : ;
+ @ A
+MM "
+
+% *
+A F
+; @
+
+4 9
+0 5
+
+
+3 8
+8 =
+
+? D
+0 5
+ !
+ !
+5 :
+0 5
+1 6
+, 1
+# (
+# (
+ "
+$ )
+* /
+ . 3
+ 5 :
+ 5 :
+ . 3
+ D I
+
+ ' ,
+ ' ,
+ 0 5
+ 7 <
+NN# .
+3 >
+> I
+, 7
+
+
+S ^
+b m
+
+1 <
+# .
+# .
+# .
+P [
+ *
+ *
+ &
+ : E
+ _ j
+ - 8
+
+OO 0ss ss0 C.
+PP% 5
+ $
+ (
+ ("
+QQ )
+
+ *F
+RR (
+
+# .
+ )
+% 0
+% 0j
+SS &
+
+
+ !
+ "
+. 7
+
+
+
+TT +
+ ":
+UU (
+$ /
+( 3
+$ /
+( 3^
+VV, >
+* <
+ 0
+ *
+1 C
+ +
+ "
+ #
+WW 4
+" 7
+XX 4
+" 7"
+ZZ
+H V
+` n"
+[[
+
+ (
+\\
+ "
+]]
+ &
+1 B
+^^
+ ^
+__
+" )
+
+
+) 0
+
+ '
+
+aa
+* ;
+7 H
+ 0
+ 0
+ 0
+ 0
+ 0
+@ Q
+D U
+? P
+C T
+ 0
+2 C
+- >
+ 0
+J [
+> O
+ )
+6 G
+# 4
+ 0
+ 0
+# 4
+ 0
+; L
+J [
+% 6
+' 8
+J [
+% 6
+' 8
+J [
+% 6
+' 8"
+cc 9
++ G
+ 1"
+ee 4
+ ,
+ + B"
+gg /
+ .
+ #"
+ii -
+ ,
+ !"
+kk 4
+ 3
+ ("
+mm ;
+ 6
+% @
+pp xx
+
+" /
+ "
+ "
+ &
+ &
+ #
+ *
+ *
+ ,^
+qq
+ (
+' 0
+' 0
+
+$ -
+ "
+ - 6F
+qq
+0 :
+# -
+
++ 5
+ #:
+qq 1
+# 5
+ #
++ =
+ +
+ss (
+
+xx
+
+
+
+
+
+
+
+
+
+
+( .
+
+ .
+zz# :
+
+
+
+|| .
+
+
+" 3
+
+ %
+1 B
+ 1
+ %
+
+
+ !
+ -
+ &
+ %
+ )
+ 1
+6 G
+E V
+G X
+0 A
+ %
+ ! 2
+ D U
+~~ #
+
+
+
+
+
+
+
+
+$ 2
+> L
+" 0
+# 1
+ -
+ -
+
+
+ . <
+ "
+ "
+ l
+
+
+
+
+
+
+
+, 7
+
+ H
+
+
+
+ %
+ !
+ !
+ !0
+
+
+
+ $
+; CT
+
+
+
+ &
+< F
+ "
+8 B
+8 Bl
+
+
+
+" +
+! *
+
+
+
+
+ l
+
+ !
+
+ ,
+' 7
+6 F
+
+
+
+ ' 7
+
+ ,
+
+4 D
+, <
+3 C
+5 E
+L \
+' 7
+( 8
+5 E
+ (
+ $T
+
+ &
+
+
+
+ %
+ 3 @
+ !
+
+ #
+
+ !
+
+* -
+ !
+ !
+ !
+
+
+
+
+
+
+
+ " %
+ " %
+
+
+ 6
+
+ +
+ "
+ "
+ 1
+ -
+/ A
+ "
+$ 6
+
+ -
+- ?
+
+ "
+ )
+
+ 0
+ "
+
+ 5
+H ]$
+
+ 3
+# 9
+, B$
+
+ 2
+L a
+, A$
+
+ ,
+< K
++ :0
+
+ $
+
+
+ $
+
+ ,
+ '
+ H
+
+ "
+
+
+
+
+. 5<
+
+ /
+
+
+
+ 0
+
+ $
+
+
+ T
+
+
+
+
+
+
+
+
+
+
+
+# 5
+ )
+
+ 0
+
+
+
+
+
+
+
+
+ #<
+
+( 3
+
+= H
+- 8
+# .0
+
+9 C
+
+
+0 :
+
+L P
+< @
+
+ %
+ $
+
+
+
+ $
+
+
+
+ "<
+
+
+
+C E
+
+
+
+' *
+o r
+
+W Y
+" $$
+
+
+* -
+" %$
+
+
+
+* -
+
+! "
+6 7
+
+) *
+> ?$
+
+
+
+
+
+
+
+
+ "
+
+( )
+
+7 <
+5 :
+
+ (
+; Q
+
+ &
+
+: A
+
+/ 6
+@ G
+
+" -
+" -T
+
+ !
+
+
+ "
+ "
+ "
+ "
+
+ !
+3 B
+
+
+
+* +
+
+
+
+, -
+
+ $
+
+1 2
+
+
+
+, .
+
+< >
+
+& /
+
+7 @
+
+
+
+, -
+
+ $
+
++ -
+
+ $
+
+; =
+
+
+
+E N
+< E
+
+% .
+: C$
+
+
+N V
+% -
+
+
+G S$
+
+
+* 2
+' /
+
+
+I U$
+
+
+
+ $
+
+
+" &
+ $$
+
+
+? E
+ "$
+
+
+F J
+ H
+
+ !
+ !
+ !
+ !
+
+ %$
+
+
+
+ (<
+
+ *
+
+
+
+ )$
+
+ &
+
+ <
+
+ "
+
+
+
+
+
+ )$
+
+5 9
+
+ 0
+
+@ D
+@ D
+
+ $
+
+
+ )
+ '
+
+ .
+
+8 <$
+
+
+
+
+
+
+Q ^
+
+
+# )H
+
+
+
+
+
+
+
+
+ *
+
+6 :
+
+A E
+
+ *
+
+6 :
+
+E I
+
+ '
+
+3 7$
+
+ $
+ .
+ .$
+
+ -
+ & ?
+ " ;
+
+9 =
+
+C K
+- 5
+
+R T
+
+6 =
+7 >
+
+ &
+
+0 4
+ T
+
+( /
+
+
+
+
+
+
+
+, 3
+
+D J
+
+8 =
+C H
+
+ #
+ '0
+
+
+
+
+5 7
+
+
+2 4
+
+* +
+ 0
+
+, 2
+
+
+( .
+
+
+
+
+ (
++ A
+
+
+
+$ %
+
+3 8
+
+/ 4
+
+( -
+- 2
+ !
+. 3
+E J
+, 1
+
+* /
+A F
+
+* /
+A F
+
+ #
+' .
+
+ $
+ ,
+
+ )
+/ @<
+
+
+! &
+
+? D
+5 :$
+
+
+
+) /0
+
+ !
+
+, 0
+$ (<
+
+ )
+
+
+ (
+ (
+
+
+A J"
+
+ .zz "
+& <
+
+ %
+& <
+
+6 E
+ !
+
+ &
+
++ 0
+
+
+9 ?<
+
+H N
+3 9
+
+* 0
++ 1
+
+ #
+ *
+
++ 1
+H N0
+
+ #
+
+
+ 0
+
+! (
+ "
+@ G
+ '
+
+
+
+0 6$
+
+< A
+R W
+N SH
+
+
+ !
+ !
+ !
+ !
+
+
+# +
+$ ,<
+
+
+
+
+
+$ *
+
+
+$ /
+
+2 @
+
+I O
+
+, 3
+
+
+ ($
+
+E L
+
+5 <<
+
+, 2
+ "
+# )
+) /
+: @
+
+
+ ,<
+
+# +
+
+? G
+
+ 0
+
+
+
+9 <
+: =$
+
+$ +
+
+- 4<
+
+$ *
+
+ !
+! '
+2 8$
+
+
+
+ (
+
+' +
+* .0
+
+
+
+
+$ *$
+
+
+
+ &H
+
+) -
+
+
+
+ "
+
+
+
+
+
+ $
+
+
+
+ $
+
+ -
+
+ <
+
+
+
+
+
+ %
+
+$ (
+3 7
+
+ -
+ 0
+
+ /
+ 2
+ .
+ .$
+
+> D
+
+ H
+
+" )
+
+
+
+
+ %$
+
+
++ /
+. 2
+
+
+
+
+ $
+ $
+ $
+
++ 1
+ $
+
+& ,
+
+
+
+0 6
+
+< A$
+
+
+) /
+ <
+
+
+
+
+
+
+
+
+
+% &T
+
+
+G K
+\ `
++ /
+8 <
+. 2
+4 8<
+
+& ,
+
+
+
+H N0
+
+" (
+
+
+D J
+
+ )
+
+7 8
+
+> C
+
+I N
+
+T Y
+
+ %
+
+3 4
+
+: ?
+
+E K
+
+Q V
+
+ (
+
+2 3
+
+ $
+
+
+ (
+
+
+" -
+ $
+
+3 @
+
+ H
+
+
+
+
+
+
+ #
+
+. P
+ > `
+
+ '<
+
+4 8
+
+
+
+
+
+? @
+
+R Z
+
+ #
+
+) -
+" &
+
+ (
+
+2 6
+ T
+
+$ +
+
+
+
+
+
+
+
+( /
+
+@ F
+
+L Q
+
+ '`
+
+- 1
+
+8 <
+
+
+
+9 =
+A E
+
+ ($
+
+2 6
+
+) -
+
+
+
+
+
+$ *
+
+ $
+ !$
+
+
+
+ $
+
+
+ #
+7 <0
+
+ (
+
+
+ #
+
+
+
+0 ?$
+
+E F
+
+= >
+
+ "
+ !$
+
+
+
+ #
+
+ !
+ 0
+
+
+
+D J
+@ F
+
+ ,
+
+5 ;
+
+ (0
+
+1 7
+
+ !
+ !<
+
+( /
+
+
+
+ <
+
+( /
+
+
+
+ <
+
+( /
+
+
+
+ 0
+
+
+
+
+ 0
+
+ (
+ '
+ +
+ '$
+
+
+# '
+
+
+
+# )
+
+ )
+2 I
+
+
+
+/ 5$
+
+< @
+
+5 9<
+
+F N
+
+ # +
+ F N
+ B J
+
+U W
+ P Rl
+
+ !
+
+
+ # '
+ ' +
+ # '
+ % )
+
+ % )$
+
+
+ $
+ $<
+
+ , 0
+
+
+ / 3
+ ) -0
+
+ & -
+
+
+ & -$
+
+
+ . 2
+ 6 :T
+
+
+
+ & +
+ * /
+ & +
+
+ . 3
+
+ '
+
+ 8 >
+
+ D I$
+
+ #
+ 0 6
+ <
+
+ %
+
+
+ $
+ $
+
+ '
+
+ - .$
+
+ '
+ / 7
+ '
+
+ 1
+
+ ? @
+
+ F K
+
+ Q V
+
+ \ a
+
+ -
+
+ ; <
+
+ B G
+
+ M S
+
+ Y ^
+
+ 0
+
+ : ;
+
+ -
+ 0<
+
+
+
+ : C
+
+
+
+ "
+
+ 2 8$
+
+ ? C
+
+ 2 6
+
+ I Q
+ B J
+
+ X Z
+ L N
\ No newline at end of file
diff --git a/src/src/build/sonar/scanner-report/symbols-41.pb b/src/src/build/sonar/scanner-report/symbols-41.pb
new file mode 100644
index 0000000..1439892
--- /dev/null
+++ b/src/src/build/sonar/scanner-report/symbols-41.pb
@@ -0,0 +1,164 @@
+2
+ $$ BB #JJ OO$ +x
+ // // JJ) /OO5 ;ff
+
+ "
+ #
+
+ 6
+ 77 vv
+
+
+ JJ OO
+ JJ8 A
+ #""& 34
+ "223 8ii8 =uu
+3 8
+
+
+ %% DD $L
+ pp qq qq$ +
+
+
+2 9
+
+
+
+""
6
+## #77 vv
+
+ *
+$$ 33= EEE
+9 Ax
+%%& 4DD XX aa rr .ss
+ .
+
+% 3
+ "
+ (
+'' RR; F]] bb B
+)) ,, $FF
+5 @
+
+
+
+++
+,, 44 ;;
+-- .. %(
+.. .. ..' (//( )(
+// 00 22- .33G H
+33! )44" *F
+== *
+ %
+ "
+: L
+ &
+4 F
+>>
+ #
+??
+ %
+
+BB
+BB$ +CC EE
+
+JJ
+JJ 'KK! (
+
+JJ0 6
+
+JJB H
+
+OO
+OO "PP RR !
+OO, 3QQ5 <RR( /
+OO< BQQ> DSS# )
+QQ !RR1 9
+WW jj "
+WW) 1XX #
+WWA HXX% ,
+
+\\ !
+
+``
+``& *bb
+
+ee
+ee" )jj& -
+ff hh ii- 32
+gg gg gg( )hh& 'jj# $
+
+pp +
+qq xx }}
+rr ss# +tt$ ,
+tt uu xx "
+
+' 8$
+
+$ +
+
+ $
+
+
+# +
+, 4$
+
+
+
+C D0
+
+' -
+
+
+ &$
+
+! %
+& *
+( ,
+
+
+ +$
+
+ "
+
+! '$
+
+
+
+ $
+
+
+
+
+
+ $
+
+
+
+% 1
+
+ !SS "$
+
+, 4
+' /
+" *
+
+ #
+
+
+
+$ *
+ !$
+
+
+
+ 0
+
+
+
+( )
+( )$
+
+
+
+- .
\ No newline at end of file
diff --git a/src/src/build/sonar/scanner-report/symbols-42.pb b/src/src/build/sonar/scanner-report/symbols-42.pb
new file mode 100644
index 0000000..a19418f
--- /dev/null
+++ b/src/src/build/sonar/scanner-report/symbols-42.pb
@@ -0,0 +1,39 @@
+
+ ** 55
+ $rr
+ 77$ (::$ (??$ (@@! %FF$ (LL% )NN% )SS# 'UU# 'XX$ (__% )``# 'ee) -gg) -ll' +nn' +
+ '' 11 2
+ "" (( -- 22
+ "!!# /F
+ ## $$ %% .. // 00
+ ,, --* +..) *//( )00, -22( )AA. /BB- .CC( )DD$ %HH- .KK( )RR& 'YY. /]], -dd, -kk* +P
+ "66, 1>> !EE) .PP! &[[" 'ii% *yy #
+ &II $bb (@
+, ?{{& 9}}& 9& 9
+& 9
+" 5
+
+!!
n
+"" -- @@ DD KK LL NN __ dd ee gg n
+## .. AA BB HH II QQ YY \\ bb jj
+$$ //
rr
<
+%% 00 ?? FF GG XX
+&& "==
+ 2
+'' 11 77 88 :: Z
+(( 22 RR SS UU `` kk ll nn
+
+**
+**! (++ ,,
+
+55 F
+55 $AA% ,BB "CC HH% ,YY% ,]] !
+553 766 == >> CCL PEE GG "II9 =JJ PP PP6 :QQ/ 3[[ \\ #^^ $bb= Acc ii ii: >jj3 7rr: >tt
+55A K66
+55U \88! (
+ww tt P
+ww, 0xx yy zz zz# '|| ~~ ~~) -4
+xx {{M O}}K ML N
+M O
+
+ #
\ No newline at end of file
diff --git a/src/src/build/sonar/scanner-report/symbols-43.pb b/src/src/build/sonar/scanner-report/symbols-43.pb
new file mode 100644
index 0000000..4bea7ff
--- /dev/null
+++ b/src/src/build/sonar/scanner-report/symbols-43.pb
@@ -0,0 +1,484 @@
+V
+ NN ll nn pp
+
+
+ "
+ &
+
+( 6
+
+ F
+
+
+0 ;
+
+
+0 ;
+ (
+( 9:
+ $
+ !
+/ <
+
++ 8v
+
+O V
+K R
+, 3
+
+' .
+
+' .
+
+ %:
+ &
+ '
+, ;
+2 A
+ /R
+
+
+$ *
+/ 5
+
+$ *
+ &
+ #\\ \\" .j
+ (
+
+
+
+
+
+
+
+
+
+
+
+ )
+
+ !
+!! SS ".
+"" $
+
+% /
+- 7
+##% >
+5 N
+$$ ,==- ?
+%% ,JJ ZZ .8
+&& qq %
+ !
+ (
+
+'' %
+ "
+
+(( #8
+)) "aa $
+ '
+ ,
+ '
+
+**
+++
+) 1
+
+,,
+-- aa
+. 2
+$ (
+. 2
+$ (
++ /
+/ 3
+/ 3
+
+
+. 2
+ $
+ "
+..
+
+ #
+//
+
+% -
+
+" *
+
+% -
+
+" *
+
+% -
+
+' /:
+00
+
+N S
+
+
+22 YY# $aa8 9
+' (
+) *
+
+2 3
+< =
+) *
+) *
+3 4
+4 5
+; <
+C D
+( )
+F G
++ ,
+@ A
+; <
+C D
+( )
+F G
++ ,
+
+
+
+
+> ?"
+33 "
+0 5
+, 1:
+44# .
+ *
+ *
+ &
+ &t
+55% 5]] )
+ %
+
+ $
+ $
+
+% 5
+' 7
+( 8
+
+66 (
+
+88 :
+==
$
+# :
+0 G
+/ F
+ 2F
+>> .
+> M
+: I
+B Q
+B Q
+B QF
+@@ ;
+! =
+! =
+ :
+ 6
+" >:
+BB 8
+ 7
+ 3
+ 0
+ 9
+
+DD :
+FF ;ZZ? Z
+HH 6
+ 6,
+JJ /ZZ
+
+ 6
+LL #[[ ^^ "
+
+ (>
+NN "`` mm mm: Fpp. :
+ ,
+PP $kk
+
+
+
+SS
+SS# )TT
+\\ ]] ^^$ *
+aa
bb$ *
+
+ff
+ll mm( 0nn* 2
+nn 'qq> Hww' 1
+oo !rr !vv
+pp! +qq- 7
+
+
+
+ &
+ <
+
+
+
+
+
+' 2
+
+ #
+* 8
+
+ ,
+
+8 B
+
+
+ H
+
+
+
+
+
+
+ H
+
+ !
+
+
+
+
+
+
+ #
+
+) *
+
+ #
+
+) *$
+
+
+
+ ,:
+
+ ~~
+ %
+
+ $
+
+ -
+ 4
+ 0H
+
+ )
+
+
+
+
+# 00
+
+
+, 5
+/ 8
+% .
+
+
+
+
+ !
+ <
+
+
+
+
+4 <
+# +
+
+
+3 =0
+
+
+/ 4
+
+/ 4
+
+! ,
++ 6$
+
+
+
+6 A$
+
+
+" '
+ $
+
+
+% ,
+! (
+
+$ +
+
+< B
+ "
+
+H M
+7 <$
+
+
+ ,
+
+
+
+
+
+
+
+% &$
+
+
+
+' -
+
+ 4
+ ;0
+
+ )
+
+
+ 0
+
+
+, 5
+/ 8
+% .
+
+
+
+
+ !
+
+
+ $
+ ,
+
+
+
+0 6$
+
+< A
+
+ "
+
+ 'll! 2
+ .
+
+ %
+ "
+
+ ww &
+ *<
+
+' .
+- 4
+
+? F
+M T
+
+ &
+. 60
+
+% +
+
+
+
+
+ 0
+
+" (
+
+
+H N
+
+ "
+ %0
+
+ "
+* 2
+
+ 0
+
+! '
+
+
+
+
+ 0
+
+ $
+
+
+D JH
+
+ +
+& 8
+1 C
+ .
+ "
+
+
+4 ;
+% ,
+
+ "
+
+
+ &
+
+
+/ 6
+% ,
+
+= A
+2 6
+
+ "
+* 2$
+
+! '
+
+
+
+ &
+ /
+
+/ 6
+% ,
+
+ "
+
+
+ LL [[ %
+
+
+
+& -$
+
+6 <
+
+# )
+
+ #
+
+
+ (
+
+2 6
+ $
+
+
+
+ $
\ No newline at end of file
diff --git a/src/src/build/sonar/scanner-report/symbols-44.pb b/src/src/build/sonar/scanner-report/symbols-44.pb
new file mode 100644
index 0000000..1ad25b7
--- /dev/null
+++ b/src/src/build/sonar/scanner-report/symbols-44.pb
@@ -0,0 +1,56 @@
+<
+ mm qq$ 1rr? Luu$ 1vv )2
+ )33* :DD+ ;HH) 9KK# 3
+ *##1 B
+ $22 22# 02
+ 11 !<<% ,DD !HH P
+ NN NN$ *OO &\\$ *]]% +``% +qq\ b
+ << SS
+ VV
+ !gg gg% 0F
+ __? @hh( )oo' (pp. /tt' (yy+ ,F
+ "550 5==2 7@@H MPP %QQ %ii %P
+# .%% && '' 33 77 ?? ??4 ?
+ +LL )
+ +NN4 D
+!! ,rr% 6
+
+## (
+$$" ,>>
+** %\\@ I
+++ .[[$ 6
+,, *ZZ* 8
+.. #VV !
+
+11
+11" )55
+111 =44 (882 >
+22 33 66 (
+44 44 441 288? @
+<< $SS ,
+<<- 4==
+<<: B@@. 6
+
+DD
+DD" )EE
+DD< LEE (
+DDT `EE* 6
+HH EE d
+HH 'LL9 @NN+ 2SS- 4__ %gg1 8pp #qq> Err #uu> E
+HH: Jzz Z
+HHR ^JJ (KK PP> JSS6 BVVM YqqG SuuG Szz1 =
+II nn d
+JJ JJ JJ1 2KK PPK LSSC DVVZ [qqT UuuT Uzz> ?(
+LL [[ hhN RiiB F(
+MM ZZ __ tt9 @Z
+NN OO PP QQ \\ ]] `` ii uuX ^d
+SS TT TT! "UU WW ZZ [[ \\6 7cc dd <
+gg hh oo tt yy zzB D(
+mm +qq !uu !yy= J
+ *hh> M
+
+/ 3
+
+ &ggK V
+
+ (QQ@ M
\ No newline at end of file
diff --git a/src/src/build/sonar/scanner-report/symbols-45.pb b/src/src/build/sonar/scanner-report/symbols-45.pb
new file mode 100644
index 0000000..4a58660
--- /dev/null
+++ b/src/src/build/sonar/scanner-report/symbols-45.pb
@@ -0,0 +1,20 @@
+
+ )* :
+
+ ##
+ "--
+ +((
+
+
"
+
+
+! (
+; K .
+S _0 <
+
+""
+
+'' !
+''& *((F J
+
+,,
\ No newline at end of file
diff --git a/src/src/build/sonar/scanner-report/symbols-46.pb b/src/src/build/sonar/scanner-report/symbols-46.pb
new file mode 100644
index 0000000..53986d3
--- /dev/null
+++ b/src/src/build/sonar/scanner-report/symbols-46.pb
@@ -0,0 +1,20 @@
+
+ )* :
+
+ ""
+ ",,
+ +''
+
+
"
+
+
+! (
+; K .
+S _0 <
+
+!!
+
+&& !
+&&& *''F J
+
+++
\ No newline at end of file
diff --git a/src/src/build/sonar/scanner-report/symbols-5.pb b/src/src/build/sonar/scanner-report/symbols-5.pb
new file mode 100644
index 0000000..6ccfc6b
--- /dev/null
+++ b/src/src/build/sonar/scanner-report/symbols-5.pb
@@ -0,0 +1,153 @@
+b
+ 99 99/ 2>> >>/ 2
+
+. 1
+
+. 1
+
+
6
+ (99C L>>C L
+B K
+B K
+
+ "
+
+ %
+
+ '
+
+ '
+
+!! *
+
+"" .
+
+## 1
+
+$$ *
+
+&& 6
+
+'' 9
+
+(( 5
+
+)) 7
+
+** 5
+
+++ 5
+
+-- 0
+
+.. *
+
+// *6
+00 &999 @>>9 @
+8 ?
+8 ?
+
+11 %
+
+22# '
+
+33# ,
+
+99 ,
+
+>> ,
+
+@@
+
+CC
+
+DD
+
+II
+
+OO
+
+UU
+
+[[
+
+bb
+
+hh
+
+nn
+
+tt
+
+zz
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ $
+
+
+2 =
+2 =
+
+
+
+
+
+
+
+
+
+
+
+ $
+
+
+* /
+/ 4
+
+
+
+
+2 7
+
+
+
+
+
+ &22* 2
+
+# '
+
+ /
+
+ 1
+
+# /
+
+# 4223 D
+
+ +
+
+ &33/ 7
+
+# ,
+
+# /
+
+# /
+
+# 4338 I
+
+ +
\ No newline at end of file
diff --git a/src/src/build/sonar/scanner-report/symbols-6.pb b/src/src/build/sonar/scanner-report/symbols-6.pb
new file mode 100644
index 0000000..9fd4f74
--- /dev/null
+++ b/src/src/build/sonar/scanner-report/symbols-6.pb
@@ -0,0 +1,386 @@
+:
+ $
+
+# 0
+
+# 0"
+
+ &
+8 ?
+
+
+ -
+ .
++ 9
+
+$ 2
+ .
++ 9
+ '
+ (
+ +
+ +
+ +
+ / ) 9.
+
+
+
+
+# .HH II JJ MM NN OO PP QQ RR WW &
+ "
+4 ?
+0 ;
+ "
+4 ?
+0 ;
+ "
+0 ;
+ !.
+# 0
+6 C
+6 C
+6 C
+# .11 22 33 44 55 66 77 88 99 :: ;; << == >> ?? @@ AA BB CC KK LL ^^ )aa aa4 ?bb bb0 ;jj )mm mm4 ?nn nn0 ;oo zz zz4 ?{{ {{0 ;
+
+4 ?
+
+0 ;
+
+
+
+
+
+
+
+6 A
+ !
+8 C
+ "
+
+
+7 B
+
+
+
+
+
+
+
+
+B M
+
+
+B M
+
+ ',
+
-- &
+ +
+ /
+!! '
+
+## '
+& 0
+%% 00 GG WW
^^? D`` jj? Dll ww #yy
+ #
+
+ #
+
+ #
+
+ #
+
+ #
+
+ #
+
+ #
+
+5 :
+
+
+
+
+- 2
+- 2
+$ )
+
+$ )
+&& 00 $^^E I`` jjE Ill ww$ (yy
+$ (
+
+
+
+
+$ (
+$ (
+! %
+$ (
+
+
+
+
+
+3 7
+* .
+
+* .f
+(( GG $WW
+$ (
+$ (
+$ (
+! %
+; ?
+3 7.
+++ #
+
+
+ :
+--' 0
+ %
+
+
+
+// 5
+ (
+FF 5
+ (
+UU =
+ 0
+\\ L
+ ?
+hh L
+ ?
+uu L
+ ?
+
+ L
+ ?
+
+ J
+ =
+
+ J
+ =
+
+ J
+ =
+
+ B
+ 5
+
+ E
+ 8
+
+ B
+ 5
+
+
+ /
+
+' .
+ $
+
+
+
+ 0
+
+/ 1
+
+
+" $
+ $
+
+ *
+ !
+ %
+
+: <
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ +
+a lx
+
+
+
+
+
+
+! '
+2 8
+ !
+, 2
+
+
+
+
+
+
+ -
+
+
+
+ #
+ <
+
+3 5
+
+
+
+
+
+
+
+
+
+
+
+
+$ *
+
+
+
+$ *
+
+
+
+$ *
+
+
+
+$ *$
+
+
+
+ 0
+
+/ 1
+
+
+" $
+
+$
+
+ *
+ !
+ %T
+
+: <
+
+
+
+
+
+
+
+
+
+
+
+
+
+, 7
+
+@ G
+0 7
+
+ $
+
+( *
+
+
+
+ H
+
+) +
+
+
+
+& (
+& (`
+
+1 ;
+
+
+
+
+
+
+ $
+
+A K
+ $
+S ]$
+
+
+
+ $
+
+
+
+ &
+
+
+ <
+
+, .
+
+
+
+
+
+
+
+
+ H
+
+, .
+
+
+
+
+
+
+
+
+
+0
+
+
+
+
+$ *
+
+
+
+
+, .
+
diff --git a/src/src/build/sonar/scanner-report/symbols-7.pb b/src/src/build/sonar/scanner-report/symbols-7.pb
new file mode 100644
index 0000000..9337dad
--- /dev/null
+++ b/src/src/build/sonar/scanner-report/symbols-7.pb
@@ -0,0 +1,314 @@
+Z
+ <<) 6==) 6EE$ 1FFG TGGG THH. ;II/ <JJ8 E
+ &&&# 2.
+ "
+
+
+ "
+ $
+ ,
+ ,
+ II (
+ !'' #66 !66" ,
+ YY [[ 8
+ -\\
+
+
+ P
+ YY
+
+
+
+
+ :
+
+
+
+
+
"
+
+
+
+ HH
+ D
+!!# .nn5 @
+' 2
+. 9
+ #
+6 A
+""# .DD: EEE
+ FF 'GG 'NN !OO PP ee5 @
+9 D
+ #
+6 A
+
+ $
+ "
+##1 6MM `` "ee "ii "nn "
+0 5
+0 5
+" '
+" '
+" '
+" '
+" '
+" '
+" '
+" '
+
+
+&&
+''$ ,66 77 88 99 :: ;; << == ^^ yy
+
+
+ N
+)) 'TT \\ #
+ #
+ #
+ #
+ "
+++ #
+
+ B
+-- %771 9__
+
+
+ 6
+.. *883 @cc
+
+ B
+// %991 9hh
+
+
+ 6
+00 *::3 @ll
+
+
+22 ';;3 =qq 2
+33 /<<O a==V hrr #yy+ =
+DD 7LLC Z
+LL 4
+$ >
+
+SS
+
+YY h
+YY ^^ "dd mm yy# &zz {{' *~~# &
+D G
+D G<
+YY* 4``) 3ee) 3ii) 3nn) 3ss) 32
+YY= F``5 >ff) 2ii5 >oo) 22
+YYQ ^``@ Mff5 Bii@ Moo5 B<
+ZZ aa !ffP Yjj !ooP Yss b
+[[ `` ee ii nn
+
+
+
+ >
+\\ `` ee ii nn
+ 2
+]] dd eeL Nmm nnL NN
+xx #{{ $~~
+& 2
+
+; G
++ 7
+
+/ 1
+3 5
+
+ 0
+
+
+ "
+D G
+* -H
+
+- 3
+B H
+
+ #
+F L
+B H$
+
+
+& (
+& (0
+
+
+ #
+
+G M<
+
+
+ #
+
+
+G M0
+
+% /
+
+
+/ 9
+
+ H
+
+
+ "
+
+
+D G
+; >T
+
+& /
+
+" +
+. 7
+C L
+. 7
+C L<
+
+: G
+9 F
+O \
+9 F
+O \T
+
+
+
+
+
+
+
+ H
+
+
+
++ -
+/ 1
+
+/ 1<
+
+
+
+
+
+ 0
+
+
+
+
+
+
+
+
+
+ H
+
+
+ "
+
+
+D G
+; ><
+
+- 3
+. 4
+. 4
+. 4
+. 4T
+
+< E
+( 1
+6 ?
+6 ?
+) 2
+6 ?
+) 2T
+
+P ]
+3 @
+A N
+A N
+5 B
+A N
+5 BT
+
+
+
+
+
+
+
+ H
+
+
+
+1 3
+M O
+
+M O<
+
+
+
+
+
+ 0
+
+
+
+
+ \
+
+ !ff (oo (
+4 B
+4 B
+ (
+ (
++ 9$
+
+) 2
+# ,
+; D$
+
+ $
+ #
+ #<
+
+* ,
+
+
+= ?
+" $<
+
+5 >
+) 2
+ (
+: C
+G P
+
+I V
+ ,x
+
+
+
+
+
+
+
+
+
+
+. 10
+
+
+
+ +
+ #
+
+
+@ D
+
+
+
+ !
\ No newline at end of file
diff --git a/src/src/build/sonar/scanner-report/symbols-8.pb b/src/src/build/sonar/scanner-report/symbols-8.pb
new file mode 100644
index 0000000..8962070
--- /dev/null
+++ b/src/src/build/sonar/scanner-report/symbols-8.pb
@@ -0,0 +1,35 @@
+
+ NN #
+ %% << (
+ -## )(( ::1 A
+ $$ ;; "F
+ !!$ .55' 199 99* 4CC& 0II
+
& .
+ #%% << (
+ ,, :: ==
+
+!!
+!! "##> A
+!!/ 7## ''
+
+$$
+
+++
+
+00
+
+55 &
+552 466% '
+99 #:: &
+
+;;# $
+
+CC %
+
+CC1 3
+
+II -
+
+NN
+
+NN$ %
\ No newline at end of file
diff --git a/src/src/build/sonar/scanner-report/symbols-9.pb b/src/src/build/sonar/scanner-report/symbols-9.pb
new file mode 100644
index 0000000..f0e1770
--- /dev/null
+++ b/src/src/build/sonar/scanner-report/symbols-9.pb
@@ -0,0 +1,71 @@
+
+ CC& ,<
+ 99 ;; ==0 :??/ 9AA
+
+
+
+ ,
+
+ 2
+
+ 1
+
+ 2
+
+ 1
+
+"" 5
+
+$$ 4
+
+&& 7
+
+(( -(
+** 33 FF
VV (
+,, 44
JJ
ZZ (
+.. 55 NN
^^ !(
+00 66 RR
bb
+
+22
+
+99 .
+
+993 ;
+
+;; .
+
+;;3 ;
+
+== /
+
+==; =
+
+?? .
+
+??: <
+
+AA 6
+
+CC %
+
+CC- .
+
+EE
+EE !FF
+
+II
+II #JJ
+
+MM
+MM% 1NN )
+
+QQ
+QQ# *RR
+
+UU
+
+YY
+
+]]
+
+aa
\ No newline at end of file
diff --git a/src/src/build/sonar/scanner-report/syntax-highlightings-10.pb b/src/src/build/sonar/scanner-report/syntax-highlightings-10.pb
new file mode 100644
index 0000000..e0cbbab
--- /dev/null
+++ b/src/src/build/sonar/scanner-report/syntax-highlightings-10.pb
@@ -0,0 +1,242 @@
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+""
+
+##
+
+&&
+&&
+''
+''
+''
+''. 3
+))
+))
+))
+))
+))+ 0
+++
+
+++
+++
+++3 6
+00
+
+00
+00
+00
+00- .
+22
+
+22
+22
+22
+224 5
+44
+
+44
+44
+44
+442 3
+66
+
+66
+66
+66
+669 :
+88
+
+88
+88
+88
+889 :
+::
+<<
+<<
+>>
+>>
+@@
+BB
+DD
+DD
+FF
+HH
+JJ
+
+LL
+OO
+PP
+QQ
+RR
+UU
+
+WW
+YY
+\\
+\\
+dd
+
+dd
+dd* 0
+ee
+ff
+
+mm
+
+rr_ a
+ss
+
+xx
+xx\ ]
+yy
+
+~~` b
+
+
+
+
+
+
+# )
+
+
+
+
+ N
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+% )
+
+2 9
+
+K O
+
+
+
+
+
+
+= >
+
+
+
+
+ ,
+
+
+
+
+
+- A
+
+
+
+
+
+
+) -
+
+6 =
+
+O S
+
+
+
+
+% &
+
+
+
+
+
+
+
+K O
+
+Q U
+
+
+
+ (
+
+< D
+
+" +
+
+D I
+
+K N
+
+
+
+
+
+ U
+
+
+
+
+
+
+
+
+$ +
+
+= A
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
\ No newline at end of file
diff --git a/src/src/build/sonar/scanner-report/syntax-highlightings-11.pb b/src/src/build/sonar/scanner-report/syntax-highlightings-11.pb
new file mode 100644
index 0000000..4e4bab2
--- /dev/null
+++ b/src/src/build/sonar/scanner-report/syntax-highlightings-11.pb
@@ -0,0 +1,627 @@
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+""
+
+##
+
+$$
+
+&&
+
+))
+))
+**
+**
+**
+**. 3
+,,
+,,
+,,
+,,
+,,+ 0
+..
+
+..
+..
+..3 6
+77
+
+77
+77
+77
+77( )
+99
+
+99
+99
+99
+992 3
+;;
+
+;;
+;;
+;;
+;;1 2
+==
+
+==
+==
+==
+==2 3
+??
+
+??
+??
+??
+??4 5
+AA
+
+AA
+AA
+AA
+AA3 4
+CC
+
+CC
+CC
+CC
+CC1 2
+EE
+
+EE
+EE
+EE
+EE/ 0
+GG
+
+GG
+GG
+GG
+GG- .
+II
+
+II
+II
+II
+II* +
+KK
+
+KK
+KK
+KK
+KK/ 1
+MM
+
+MM
+MM
+MM
+MM1 3
+OO
+
+OO
+OO
+OO
+OO- /
+QQ
+
+QQ
+QQ
+QQ
+QQ4 6
+SS
+
+SS
+SS
+SS
+SS6 8
+UU
+
+UU
+UU
+UU
+UU. 0
+WW
+
+WW
+WW
+WW
+WW- /
+YY
+[[
+]]
+]]
+__
+__
+aa
+aa
+cc
+cc
+ee
+ee
+gg
+gg
+ii
+ii
+kk
+kk
+mm
+oo
+oo
+qq
+qq
+ss
+ss
+uu
+uu
+ww
+ww
+yy
+{{
+}}
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+$ (
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ $
+
+
+
+
+
+P Y
+
+
+
+
+
+
+
+
+
+
+
+ :
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ !
+
+# &
+
+
+
+
+
+
+
+
+
+$ %
+
+ D
+
+
+
+
+
+# &
+
+
+
+ ;
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ 5
+
+
+
+
+
+ E
+
+: <
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+= >
+
+
+
+
+
+
+
+
+
+
+
+
+
+> ?
+
+
+
+
+
+
+
+
+
+: ;
+
+
+
+: <
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+A B
+
+
+
+
+
+
+
+
+
+& *
+
+
+
+
+
+
+
+
+
+
+
+# '
+
+" %
+
+
+
+
+ "
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ R
+
+
+
+
+
+ !
+
+
+
+& )
+
+
+
+
+
+ $
+
+
+
+
+
+
+
+
+
+
+ "
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+8 9
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+= >
+
+
+
+ 0
+
+
+
+
+
+1 E
+
+
+
+
+
+
+
+
+
+0 I
+
+
+
+
+
+( -
+
+0 1
+
+
+
+
+
+
+
+
+ )
+
+
+
+
+
+0 T
+
+
+
+) *
+
+
+
+
+
+
+
+^ a
+
+/ 4
+
+6 9
+
+
+
+^ a
+
+/ :
+
+S Y
+
+
+
+
+
+
+
+ Y
+
+
+
+
+
+
+
+
+
+
+
\ No newline at end of file
diff --git a/src/src/build/sonar/scanner-report/syntax-highlightings-117.pb b/src/src/build/sonar/scanner-report/syntax-highlightings-117.pb
new file mode 100644
index 0000000..d1c74ac
--- /dev/null
+++ b/src/src/build/sonar/scanner-report/syntax-highlightings-117.pb
@@ -0,0 +1,56 @@
+
+
+
+
+
+
+ $
+$ &
+
+
+
+
+ *
+
+ +
+
+ &
+
+ B
+B C
+
+
+ .
+
+ 2
+
+ !
+
+
+
+
+
+! *
+ #
+$ -
+
+ *
+!!
+!! ,
+!!, .
+##
+$$
+$$ 1
+%%
+%% *
+&&
+&& ,
+''
+''! '
+(( #
+(($ *
+))
+))
+)) "
+
+++
\ No newline at end of file
diff --git a/src/src/build/sonar/scanner-report/syntax-highlightings-118.pb b/src/src/build/sonar/scanner-report/syntax-highlightings-118.pb
new file mode 100644
index 0000000..2afce5b
--- /dev/null
+++ b/src/src/build/sonar/scanner-report/syntax-highlightings-118.pb
@@ -0,0 +1,38 @@
+
+
+
+
+
+
+ $
+$ &
+
+
+
+
+ >
+
+ '
+
+ (
+
+
+
+ %
+
+ "
+" #
+
+
+ +
+
+ ,
+
+ '
+
+ C
+
+ 6
+6 9
+
+
\ No newline at end of file
diff --git a/src/src/build/sonar/scanner-report/syntax-highlightings-119.pb b/src/src/build/sonar/scanner-report/syntax-highlightings-119.pb
new file mode 100644
index 0000000..2f874b2
--- /dev/null
+++ b/src/src/build/sonar/scanner-report/syntax-highlightings-119.pb
@@ -0,0 +1,82 @@
+
+
+
+
+
+
+ $
+$ &
+
+
+
+
+ H
+
+ $
+
+ .
+
+ '
+
+ (
+( )
+
+
+
+
+ %
+
+ ,
+
+
+ $
+% +
++
+
+
+
+
+
+ $
+!!
+!! ,
+"" !
+""" (
+##
+##
+$$ $
+$$% +
+$%+
+
+''
+((
+((
+))
+)) $
+**
+** ,
+++ !
+++" (
+,,
+,,
+-- $
+--% +
+-.+
+
+00
+11
+11
+22
+22 $
+33
+33 ,
+44 !
+44" (
+55
+55
+66 $
+66% +
+67+
+
+
+88
\ No newline at end of file
diff --git a/src/src/build/sonar/scanner-report/syntax-highlightings-12.pb b/src/src/build/sonar/scanner-report/syntax-highlightings-12.pb
new file mode 100644
index 0000000..db737b3
--- /dev/null
+++ b/src/src/build/sonar/scanner-report/syntax-highlightings-12.pb
@@ -0,0 +1,425 @@
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+##
+##
+##
+$$
+$$
+$$
+$$+ 0
+&&
+&&
+((
+**
+,,
+..
+00
+
+11
+22
+33
+44
+55
+66
+99
+
+99& )
+::
+<<
+==
+AA
+DD
+EEP T
+GG
+HH #
+JJ? E
+MM
+MM "
+RR
+UU
+YY
+\\
+]]
+]]! %
+aa
+
+cc "
+dd
+dd
+dd- V
+gg
+jj
+
+jj& )
+kk
+mm
+nn
+rr
+uu
+xx
+yy #
+{{
+{{ "
+
+
+
+
+ "
+
+
+
+
+
+- V
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ &
+
+
+
+
+
+1 [
+
+
+
+
+
+
+
+
+
+
+
+ C
+
+
+
+
+
+
+
+
+
+ -
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ >
+
+
+
+
+ "
+
+
+
+
+
+
+
+
+ !
+
+ ,
+
+
+
+
+
+ B
+
+
+
+
+
+ #
+
+" %
+
+& )
+
+" %
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ "
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+7 ;
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+" &
+
+
+
+ !
+
+
+
+
+
+ E
+
+
+
+
+
+ ?
+
+
+
+ '
+
+
+
+ 2
+
+
+
+
+
+; <
+
+ +
+
+
+
+ *
+
+
+
+
+
+ ,
+
+
+
+
+
+ $
+
+
+
+ 7
+
+
+
+
+
+ .
+
+
+
+
+
+
+
+
+
+
+ "
+
+
+
+
+
+
+
+
+
+
+
+
+2 6
+
+V W
+
+" &
+
+G H
+
+
+
+
+
+
+ $
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
\ No newline at end of file
diff --git a/src/src/build/sonar/scanner-report/syntax-highlightings-120.pb b/src/src/build/sonar/scanner-report/syntax-highlightings-120.pb
new file mode 100644
index 0000000..b87b353
--- /dev/null
+++ b/src/src/build/sonar/scanner-report/syntax-highlightings-120.pb
@@ -0,0 +1,22 @@
+
+
+
+
+
+
+ $
+$ &
+
+
+
+
+ >
+
+ #
+
+ &
+
+ *
+
+ '
+' *
\ No newline at end of file
diff --git a/src/src/build/sonar/scanner-report/syntax-highlightings-121.pb b/src/src/build/sonar/scanner-report/syntax-highlightings-121.pb
new file mode 100644
index 0000000..da8c313
--- /dev/null
+++ b/src/src/build/sonar/scanner-report/syntax-highlightings-121.pb
@@ -0,0 +1,74 @@
+
+
+
+
+
+
+ $
+$ &
+
+
+
+ H
+
+
+ "
+
+
+ #
+
+
+
+
+
+
+
+
+
+ '
+
+
+
+
+
+ (
+
+
+
+
+
+
+ %
+
+ &
+
+ *
+
+ '
+' )
+
+
+
+
+
+
+
+
+
+ '
+
+ (
+
+
+
+
+
+
+ #
+
+ '
+
+ (
+( +
+
+!!
\ No newline at end of file
diff --git a/src/src/build/sonar/scanner-report/syntax-highlightings-122.pb b/src/src/build/sonar/scanner-report/syntax-highlightings-122.pb
new file mode 100644
index 0000000..b9f4cdc
--- /dev/null
+++ b/src/src/build/sonar/scanner-report/syntax-highlightings-122.pb
@@ -0,0 +1,50 @@
+
+
+
+
+
+
+ $
+$ &
+
+
+
+ H
+
+ &
+
+ '
+
+ "
+" $
+
+
+ #
+
+ +
+
+ ,
+
+
+
+
+
+
+
+
+
+
+
+
1
+
+ *
+
+ .
+
+ +
++ -
+
+
+
+
+
\ No newline at end of file
diff --git a/src/src/build/sonar/scanner-report/syntax-highlightings-123.pb b/src/src/build/sonar/scanner-report/syntax-highlightings-123.pb
new file mode 100644
index 0000000..d708da5
--- /dev/null
+++ b/src/src/build/sonar/scanner-report/syntax-highlightings-123.pb
@@ -0,0 +1,110 @@
+
+
+
+
+
+
+ $
+$ &
+
+
+
+ H
+
+ '
+
+ (
+
+ "
+" #
+
+
+ +
+
+ ,
+ "
+ # (
+
+
+
+
+
+ "
+
+
+" $
+
+
+ $
+
+
+
+
+ ,
+
+ &
+& '
+
+
+ -
+
+! /
+ !
+" 0
+
+ ,
+
+ "
+" $
+
+
+ .
+
+! /
+ !
+" 0
+
+ -
+- /
+
+
+ -
+
+! /
+ !
+" 0
+
+ ,
+ , .
+!!
+""
+"" /
+##
+##! /
+$$ !
+$$" 0
+%%
+%% .
+%%. 0
+&&
+''
+'' .
+((
+((! /
+)) !
+))" 0
+**
+** -
+**- /
+++
+,,
+--
+-- "
+..
+.. $
+//
+// %
+00
+00! '
+00' )
+
+22
\ No newline at end of file
diff --git a/src/src/build/sonar/scanner-report/syntax-highlightings-124.pb b/src/src/build/sonar/scanner-report/syntax-highlightings-124.pb
new file mode 100644
index 0000000..0e7a219
--- /dev/null
+++ b/src/src/build/sonar/scanner-report/syntax-highlightings-124.pb
@@ -0,0 +1,34 @@
+
+
+
+
+
+
+ $
+$ &
+
+
+
+
+ H
+
+ '
+
+ (
+
+
+
+
+
+ (
+
+ +
+
+ ,
+
+
+
+ A
+A D
+
+
\ No newline at end of file
diff --git a/src/src/build/sonar/scanner-report/syntax-highlightings-125.pb b/src/src/build/sonar/scanner-report/syntax-highlightings-125.pb
new file mode 100644
index 0000000..29834e3
--- /dev/null
+++ b/src/src/build/sonar/scanner-report/syntax-highlightings-125.pb
@@ -0,0 +1,43 @@
+
+
+
+
+ H
+
+ 2
+
+ '
+
+ (
+
+ "
+
+ &
+& '
+
+
+ +
+
+ ,
+
+
+
+
+
+ #
+
+
+ !
+ 8
+
'
+
+ !
+
+ +
+
+ ,
+ !
+" ,
+, /
+
+
\ No newline at end of file
diff --git a/src/src/build/sonar/scanner-report/syntax-highlightings-126.pb b/src/src/build/sonar/scanner-report/syntax-highlightings-126.pb
new file mode 100644
index 0000000..2528bef
--- /dev/null
+++ b/src/src/build/sonar/scanner-report/syntax-highlightings-126.pb
@@ -0,0 +1,93 @@
+
+
+
+
+
+
+ $
+$ &
+
+
+
+ H
+
+ 2
+
+
+
+ '
+
+ (
+
+ "
+
+
+
+
+
+
+
+ (
+
+ +
+
+
,
+
, -
+
+
+! /
+ !
+" 0
+
+ "
+
+
+
+
+
+! /
+ !
+" 0
+
+ )
+
+
+ "
+
+
+! /
+ !
+" 0
+
+ (
+
+
+ "
+
+!!
+!!! /
+"" !
+""" 0
+##
+## "
+$$
+$$
+$$ "
+''
+))
+**
+** +
+++
+++ ,
+++, -
+--
+..
+.. &
+//
+//! /
+00 !
+00" 0
+000 3
+11
+
+33
\ No newline at end of file
diff --git a/src/src/build/sonar/scanner-report/syntax-highlightings-127.pb b/src/src/build/sonar/scanner-report/syntax-highlightings-127.pb
new file mode 100644
index 0000000..55b0047
--- /dev/null
+++ b/src/src/build/sonar/scanner-report/syntax-highlightings-127.pb
@@ -0,0 +1,1135 @@
+
+
+
+
+
+
+ $
+$ &
+
+
+
+
+ &
+
+ '
+
+ 2
+
+ >
+> ?
+
+
+ *
+
+ +
+
+ &
+& '
+
+
+ (
+
+! .
+ !
+ " 0
+ 0 1
+!!
+""
+"" *
+## $
+##% 3
+$$ %
+$$& 4
+%% &
+%%' >
+&& *
+&&+ 1
+&&1 4
+((
+))
+)) 2
+** $
+**% +
+++ %
+++& 4
+,, %
+,,& )
+-- &
+--' =
+.. *
+..+ 1
+// &
+//' K
+//K N
+11
+22
+22 /
+33 $
+33% 3
+44 %
+44& 4
+55 &
+55' 8
+66 "
+66# :
+66: =
+99
+::
+:: /
+;; $
+;;% 3
+<< %
+<<& 4
+== &
+==' 8
+>> )
+>>* 0
+?? *
+??+ 1
+@@ &
+@@' K
+@@K N
+BB
+CC $
+CC% 3
+DD %
+DD& 4
+EE &
+EE' /
+FF "
+FF# ?
+FF? B
+GG
+II
+JJ
+JJ *
+KK
+KK! .
+LL !
+LL" /
+MM
+MM *
+MM* +
+OO
+PP $
+PP% 2
+QQ %
+QQ& ,
+RR "
+RR# @
+RR@ C
+TT
+UU $
+UU% 2
+VV %
+VV& ,
+WW %
+WW& )
+XX "
+XX# )
+YY &
+YY' .
+ZZ &
+ZZ' 1
+[[ (
+[[) /
+[[/ 0
+]]
+^^ (
+^^) 6
+__ )
+__* 7
+__7 8
+aa 5
+bb "
+bb# 8
+cc ,
+cc- :
+dd -
+dd. 5
+ee (
+ee) .
+ff *
+ff+ 2
+gg '
+gg( 2
+hh 5
+hh6 ;
+ii .
+ii/ 6
+jj (
+jj) -
+kk .
+kk/ Q
+kkQ T
+mm !
+nn "
+nn# 8
+oo ,
+oo- :
+pp -
+pp. <
+qq +
+qq, 6
+rr 1
+rr2 :
+ss *
+ss+ 1
+ss1 4
+tt
+uu
+ww
+xx $
+xx% 2
+yy %
+yy& ,
+zz "
+zz# @
+zz@ C
+{{
+||
+~~
+
+ *
+
+
+
+ +
+
+
+
+ $
+
+
+
+ *
+
+
+
+ 8
+
+8 ;
+
+
+
+
+
+ 0
+
+
+
+ +
+
+
+
+ ,
+
+
+
+ E
+
+
+
+! (
+
+ "
+
+# )
+
+
+
+ *
+
+
+
+ !
+
+! "
+
+
+
+
+
+! '
+
+ !
+
+" 0
+
+ !
+
+" %
+
+% &
+
+
+
+
+
+ .
+
+ $
+
+% 3
+
+ %
+
+& 4
+
+4 7
+
+
+
+
+
+ 5
+
+ $
+
+% 3
+
+ %
+
+& 4
+
+ &
+
+' 5
+
+ *
+
++ 1
+
+ !
+
+" )
+
+ "
+
+# )
+
+
+
+ 0
+
+0 3
+
+
+
+
+
+
+
+! '
+
+ !
+
+" 0
+
+ !
+
+" %
+
+% &
+
+
+
+
+
+ ,
+
+ $
+
+% 3
+
+ %
+
+& 4
+
+4 7
+
+
+
+
+
+ 3
+
+ $
+
+% 3
+
+ %
+
+& 4
+
+ &
+
+' 5
+
+ !
+
+" )
+
+ "
+
+# )
+
+ *
+
++ 1
+
+
+
+ 0
+
+0 3
+
+
+
+
+
+
+
+! '
+
+ !
+
+" 0
+
+ !
+
+" %
+
+% &
+
+
+
+
+
+ -
+
+ $
+
+% 3
+
+ %
+
+& 4
+
+4 7
+
+
+
+
+
+ 4
+
+ $
+
+% 3
+
+ %
+
+& 4
+
+ &
+
+' 5
+
+ !
+
+" )
+
+ "
+
+# )
+
+ *
+
++ 1
+
+
+
+ 0
+
+0 3
+
+
+
+
+
+
+
+! '
+
+ !
+
+" 0
+
+ !
+
+" %
+
+% &
+
+
+
+
+
+ -
+
+ $
+
+% 3
+
+ %
+
+& 4
+
+4 7
+
+
+
+
+
+ 4
+
+ $
+
+% 3
+
+ %
+
+& 4
+
+ &
+
+' 5
+
+ !
+
+" )
+
+ "
+
+# )
+
+
+
+ 0
+
+0 3
+
+
+
+
+
+
+
+! '
+
+ !
+
+" 0
+
+ !
+
+" %
+
+% &
+
+
+
+
+
+ +
+
+ $
+
+% 3
+
+ %
+
+& 4
+
+4 7
+
+
+
+
+
+ 2
+
+ $
+
+% 3
+
+ %
+
+& 4
+
+ &
+
+' 5
+
+ !
+
+" )
+
+ "
+
+# )
+
+
+
+ 0
+
+0 3
+
+
+
+
+
+
+
+
+
+ ,
+
+
+
+ *
+
+
+
+ ,
+
+
+
+ <
+
+
+
+ '
+
+
+
+ !
+
+! "
+
+
+
+
+
+ +
+
+
+
+! '
+
+ !
+
+" 0
+
+ !
+
+" %
+
+% &
+
+
+
+ $
+
+% 3
+
+ %
+
+& 4
+
+ #
+
+$ .
+
+ &
+
+' /
+
+
+
+ (
+
+( )
+
+
+
+ (
+
+) 7
+
+ )
+
+* 8
+
+
+
+ 6
+
+ /
+
+0 6
+
+6 9
+
+
+
+ (
+
+) 7
+
+ )
+
+* 8
+
+
+
+! :
+
+ *
+
++ O
+
+O R
+
+
+
+
+
+
+
+ 1
+
+ $
+
+% 3
+
+ %
+
+& 4
+
+ &
+
+' 5
+
+ *
+
++ 1
+
+ +
+
+, 3
+
+ !
+
+" )
+
+ "
+
+# )
+
+
+
+ 0
+
+0 3
+
+
+
+
+
+
+
+ ,
+
+
+
+! '
+
+ !
+
+" 0
+
+ !
+
+" %
+
+% &
+
+
+
+ $
+
+% 3
+
+ %
+
+& 4
+
+ #
+
+$ .
+
+ &
+
+' /
+
+
+
+ (
+
+( )
+
+
+
+ (
+
+) 7
+
+ )
+
+* 8
+
+
+
+ 7
+
+ /
+
+0 6
+
+6 9
+
+
+
+ (
+
+) 7
+
+ )
+
+* 8
+
+
+
+! ;
+
+ *
+
++ O
+
+O R
+
+
+
+
+
+
+
+ 2
+
+ $
+
+% 3
+
+ %
+
+& 4
+
+ &
+
+' 5
+
+ !
+
+" )
+
+ "
+
+# )
+
+ *
+
++ 1
+
+ +
+
+, 3
+
+
+
+ 0
+
+0 3
+
+
+
+
+
+
+
+ +
+
+
+
+! '
+
+ !
+
+" 0
+
+ !
+
+" %
+
+% &
+
+
+
+ $
+
+% 3
+
+ %
+
+& 4
+
+ #
+
+$ .
+
+ &
+
+' /
+
+
+
+ (
+
+( )
+
+
+
+ (
+
+) 7
+
+ )
+
+* 8
+
+
+
+ 6
+
+ /
+
+0 6
+
+6 9
+
+
+
+ (
+
+) 7
+
+ )
+
+* 8
+
+
+
+! :
+
+ *
+
++ O
+
+O R
+
+
+
+
+
+
+
+ 1
+
+ $
+
+% 3
+
+ %
+
+& 4
+
+ &
+
+' 5
+
+ !
+
+" )
+
+ "
+
+# )
+
+ *
+
++ 1
+
+ +
+
+, 3
+
+
+
+ 0
+
+0 3
+
+
+
+
+
+
+
+ +
+
+
+
+! '
+
+ !
+
+" 0
+
+ !
+
+" %
+
+% &
+
+
+
+ $
+
+% 3
+
+ %
+
+& 4
+
+ #
+
+$ .
+
+ &
+
+' /
+
+
+
+ (
+
+( )
+
+
+
+ (
+
+) 7
+
+ )
+
+* 8
+
+
+
+ 6
+
+ /
+
+0 6
+
+6 9
+
+
+
+ (
+
+) 7
+
+ )
+
+* 8
+
+
+
+! :
+
+ *
+
++ O
+
+O R
+
+
+
+
+
+
+
+ 1
+
+ $
+
+% 3
+
+ %
+
+& 4
+
+ &
+
+' 5
+
+ !
+
+" )
+
+ "
+
+# )
+
+ *
+
++ 1
+
+ +
+
+, 3
+
+
+
+ 0
+
+0 3
+
+
+
+
+
\ No newline at end of file
diff --git a/src/src/build/sonar/scanner-report/syntax-highlightings-128.pb b/src/src/build/sonar/scanner-report/syntax-highlightings-128.pb
new file mode 100644
index 0000000..d44c4d1
--- /dev/null
+++ b/src/src/build/sonar/scanner-report/syntax-highlightings-128.pb
@@ -0,0 +1,50 @@
+
+
+
+
+
+
+ $
+$ &
+
+
+
+
+ >
+
+ &
+
+ (
+( )
+
+
+ &
+
+ +
+
+ %
+
+
+
+ !
+
+ )
+) ,
+ %
+
+ &
+!!
+!! *
+""
+"" ,
+## %
+##& +
+$$
+$$ 0
+%%
+%% A
+&&
+&& "
+&&" %
+
+''
\ No newline at end of file
diff --git a/src/src/build/sonar/scanner-report/syntax-highlightings-129.pb b/src/src/build/sonar/scanner-report/syntax-highlightings-129.pb
new file mode 100644
index 0000000..1c022d2
--- /dev/null
+++ b/src/src/build/sonar/scanner-report/syntax-highlightings-129.pb
@@ -0,0 +1,123 @@
+
+
+
+
+
+
+ $
+$ &
+
+
+
+
+ >
+
+
+
+ &
+
+ '
+' (
+
+
+ *
+
+ ,
+
+ 0
+
+ )
+) *
+
+
+! '
+ !
+ " 0
+!! !
+!!" %
+""
+"" *
+""* +
+$$
+%%
+%% )
+&& $
+&&% 3
+'' %
+''& ,
+(( %
+((& )
+)) &
+))' I
+** "
+**# )
+**) ,
+,,
+-- $
+--% 2
+.. %
+..& 4
+// &
+//' 8
+//8 9
+11
+22
+22 .
+33 (
+33) /
+44 )
+44* 8
+55 )
+55* -
+66 &
+66' -
+66- 0
+88
+99
+99 -
+:: (
+::) 7
+;; )
+;;* 8
+<< *
+<<+ O
+<<O R
+==
+>>
+@@
+AA
+AA -
+BB
+BB! /
+CC !
+CC" 0
+DD
+DD %
+EE
+EE %
+FF
+FF %
+FF% (
+GG
+II
+JJ
+JJ '
+KK
+KK +
+LL
+LL ,
+MM
+MM *
+MM* ,
+NN
+OO
+OO !
+PP
+PP +
+QQ
+QQ ,
+RR
+RR -
+RR- 0
+
+SS
\ No newline at end of file
diff --git a/src/src/build/sonar/scanner-report/syntax-highlightings-13.pb b/src/src/build/sonar/scanner-report/syntax-highlightings-13.pb
new file mode 100644
index 0000000..73de6a6
--- /dev/null
+++ b/src/src/build/sonar/scanner-report/syntax-highlightings-13.pb
@@ -0,0 +1,461 @@
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+!!
+!!
+!!
+""
+""
+""
+""/ 4
+$$
+$$
+&&
+((
+
+))
+**
+++
+..
+
+..& )
+//
+11
+22
+66
+99
+<<
+== #
+??? E
+DD
+
+FF "
+GG
+GG
+GG- Z
+JJ
+MM
+
+MM& )
+NN
+PP
+QQ
+UU
+XX
+[[
+\\ #
+aa
+
+cc "
+dd
+dd
+dd- Z
+gg
+jj
+
+jj
+kk
+
+kk
+ll
+mm
+nn
+rr
+ss
+ww
+xx
+||
+~~ &
+
+
+1 _
+
+
+
+
+
+
+
+
+
+
+
+ C
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+# :
+
+
+
+ +
+
+
+
+ &
+
+
+
+ :
+
+
+
+
+
+
+
+
+ #
+
+
+
+
+
+
+
+
+
+
+
+
+ "
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+; <
+
+ +
+
+
+
+ *
+
+
+
+
+
+ ,
+
+
+
+
+
+ $
+
+
+
+ 7
+
+
+
+
+
+ 2
+
+
+
+
+
+ N
+
+
+
+
+
+
+ "
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ 7
+
+; ?
+
+0 1
+
+ #
+
+
+
+
+
+
+
+
++ .
+
+
+
+
+
+
+ 6
+
+
+
+
+
+
+
+
+
+
+
+
+$ %
+
+ #
+
+
+
+ !
+
+
+
+
+
+0 1
+
+
+
+, -
+
+2 3
+
+
+
+ !
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ 1
+
+% )
+
+ #
+
+ '
+
+
+
+% &
+
+) -
+
+F G
+
+
+
+
+
+
+
+
+, /
+
+
+
+
+
+
+ 7
+
+
+
+
+
+
+
+
+
+
+
+
+ E
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+$ '
+
+
+
+
+
+
+ 6
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
\ No newline at end of file
diff --git a/src/src/build/sonar/scanner-report/syntax-highlightings-130.pb b/src/src/build/sonar/scanner-report/syntax-highlightings-130.pb
new file mode 100644
index 0000000..7b6210a
--- /dev/null
+++ b/src/src/build/sonar/scanner-report/syntax-highlightings-130.pb
@@ -0,0 +1,111 @@
+
+
+
+
+
+
+ $
+$ &
+
+
+
+
+ >
+
+ &
+
+ '
+
+ 2
+2 3
+
+
+ *
+
+ +
+
+ &
+& '
+
+
+ /
+
+! /
+ !
+" 0
+
+ #
+!!
+!! "
+""
+"" '
+##
+## %
+##% '
+$$
+%%
+%% *
+&&
+&&! .
+'' !
+''" 0
+((
+(( 7
+))
+)) %
+**
+** -
+++
+++ %
+,,
+,, )
+--
+-- ;
+--; >
+//
+00
+00 (
+11
+11! .
+22 !
+22" (
+33 !
+33" %
+44 "
+44# *
+55
+55 #
+66
+66 &
+77
+77! =
+77= @
+88 +
+99
+99 *
+::
+::! /
+;; !
+;;" 0
+<<
+<< %
+== %
+==& 0
+==0 2
+??
+AA
+BB
+BB &
+CC
+CC +
+DD
+DD ,
+EE
+EE '
+FF
+FF /
+GG
+GG !
+GG! $
+
+HH
\ No newline at end of file
diff --git a/src/src/build/sonar/scanner-report/syntax-highlightings-131.pb b/src/src/build/sonar/scanner-report/syntax-highlightings-131.pb
new file mode 100644
index 0000000..4563bfc
--- /dev/null
+++ b/src/src/build/sonar/scanner-report/syntax-highlightings-131.pb
@@ -0,0 +1,40 @@
+
+
+
+
+
+
+ $
+$ &
+
+
+
+
+ B
+
+ (
+
+ +
+
+ ,
+
+ (
+( )
+
+
+ ,
+
+ B
+
+ %
+
+ 2
+
+! /
+ !
+" 0
+
+ 7
+7 :
+
+
\ No newline at end of file
diff --git a/src/src/build/sonar/scanner-report/syntax-highlightings-132.pb b/src/src/build/sonar/scanner-report/syntax-highlightings-132.pb
new file mode 100644
index 0000000..207ef31
--- /dev/null
+++ b/src/src/build/sonar/scanner-report/syntax-highlightings-132.pb
@@ -0,0 +1,24 @@
+
+
+
+
+
+
+ $
+$ &
+
+
+
+
+ >
+
+ &
+
+ "
+
+ "
+
+
+
+ 1
+1 4
\ No newline at end of file
diff --git a/src/src/build/sonar/scanner-report/syntax-highlightings-133.pb b/src/src/build/sonar/scanner-report/syntax-highlightings-133.pb
new file mode 100644
index 0000000..fa30063
--- /dev/null
+++ b/src/src/build/sonar/scanner-report/syntax-highlightings-133.pb
@@ -0,0 +1,52 @@
+
+
+
+
+
+
+ $
+$ &
+
+
+
+
+ *
+
+ ,
+
+ &
+
+ B
+B C
+
+
+ 0
+
+ *
+
+ ,
+
+! (
+ !
+" )
+ "
+# *
+
+ 2
+
+ B
+ B D
+""
+##
+## :
+$$
+$$ +
+%%
+%% ,
+&&
+&& '
+''
+'' !
+''! #
+
+))
\ No newline at end of file
diff --git a/src/src/build/sonar/scanner-report/syntax-highlightings-134.pb b/src/src/build/sonar/scanner-report/syntax-highlightings-134.pb
new file mode 100644
index 0000000..0d62220
--- /dev/null
+++ b/src/src/build/sonar/scanner-report/syntax-highlightings-134.pb
@@ -0,0 +1,50 @@
+
+
+
+
+
+
+ $
+$ &
+
+
+
+
+ >
+
+ !
+
+ "
+" #
+
+
+ )
+
+ *
+
+ +
++ .
+
+
+ %
+
+ *
+
+ +
+
+ "
+
+ #
+
+ $
+!!
+!!
+""
+"" %
+##
+##
+$$ %
+$$& +
+$$+ .
+
+%%
\ No newline at end of file
diff --git a/src/src/build/sonar/scanner-report/syntax-highlightings-135.pb b/src/src/build/sonar/scanner-report/syntax-highlightings-135.pb
new file mode 100644
index 0000000..fd8d196
--- /dev/null
+++ b/src/src/build/sonar/scanner-report/syntax-highlightings-135.pb
@@ -0,0 +1,50 @@
+
+
+
+
+
+
+ $
+$ &
+
+
+
+
+ >
+
+ !
+
+ "
+" #
+
+
+ )
+
+ *
+
+ +
++ .
+
+
+ %
+
+ *
+
+ +
+
+ "
+!!
+!! #
+""
+"" $
+##
+##
+$$
+$$ %
+%%
+%%
+&& %
+&&& +
+&&+ .
+
+''
\ No newline at end of file
diff --git a/src/src/build/sonar/scanner-report/syntax-highlightings-136.pb b/src/src/build/sonar/scanner-report/syntax-highlightings-136.pb
new file mode 100644
index 0000000..0dfe4c0
--- /dev/null
+++ b/src/src/build/sonar/scanner-report/syntax-highlightings-136.pb
@@ -0,0 +1,58 @@
+
+
+
+
+
+
+ $
+$ &
+
+
+
+
+ >
+> ?
+
+
+ %
+
+ +
++ .
+
+
+ (
+
+ .
+. 0
+
+
+ (
+
+ .
+. 1
+!!
+""
+"" $
+##
+## *
+##* ,
+%%
+&&
+&& .
+''
+'' 4
+''4 6
+))
+**
+** $
+++
+++ *
+++* -
+--
+..
+.. ,
+//
+// 2
+//2 5
+
+00
\ No newline at end of file
diff --git a/src/src/build/sonar/scanner-report/syntax-highlightings-137.pb b/src/src/build/sonar/scanner-report/syntax-highlightings-137.pb
new file mode 100644
index 0000000..4996487
--- /dev/null
+++ b/src/src/build/sonar/scanner-report/syntax-highlightings-137.pb
@@ -0,0 +1,22 @@
+
+
+
+
+
+
+ $
+$ &
+
+
+
+
+ >
+> ?
+
+
+ %
+
+ +
++ .
+
+
\ No newline at end of file
diff --git a/src/src/build/sonar/scanner-report/syntax-highlightings-138.pb b/src/src/build/sonar/scanner-report/syntax-highlightings-138.pb
new file mode 100644
index 0000000..37c5244
--- /dev/null
+++ b/src/src/build/sonar/scanner-report/syntax-highlightings-138.pb
@@ -0,0 +1,94 @@
+
+
+
+
+
+
+ $
+$ &
+
+
+
+
+ >
+> ?
+
+
+ '
+
+ 1
+1 3
+
+
+ %
+
+ +
++ -
+
+
+ (
+
+ .
+. 0
+!!
+""
+"" (
+##
+## .
+##. 1
+%%
+&&
+&& $
+''
+'' *
+''* ,
+))
+**
+** .
+++
+++ 4
+++4 6
+--
+..
+.. $
+//
+// *
+//* -
+11
+22
+22 ,
+33
+33 2
+332 5
+55
+66
+66 )
+77
+77 /
+77/ 1
+88
+99
+99 +
+::
+:: 1
+::1 3
+;;
+<<
+<< %
+==
+== &
+==& (
+>>
+??
+?? )
+@@
+@@ *
+@@* ,
+AA
+BB
+BB %
+CC
+CC $
+CC$ &
+
+DD
\ No newline at end of file
diff --git a/src/src/build/sonar/scanner-report/syntax-highlightings-139.pb b/src/src/build/sonar/scanner-report/syntax-highlightings-139.pb
new file mode 100644
index 0000000..b8497b5
--- /dev/null
+++ b/src/src/build/sonar/scanner-report/syntax-highlightings-139.pb
@@ -0,0 +1,64 @@
+
+
+
+
+
+
+ $
+$ &
+
+
+
+
+ >
+> ?
+
+
+ )
+
+ 2
+2 4
+
+
+ *
+
+ 0
+0 3
+
+
+ #
+
+ )
+) +
+
+!!
+!! &
+""
+"" ,
+"", /
+$$
+%%
+%% %
+&&
+&& +
+&&+ -
+((
+))
+)) ,
+**
+** 2
+**2 4
+++
+,,
+,, %
+--
+-- +
+--+ -
+..
+//
+// )
+00
+00 /
+00/ 1
+
+11
\ No newline at end of file
diff --git a/src/src/build/sonar/scanner-report/syntax-highlightings-14.pb b/src/src/build/sonar/scanner-report/syntax-highlightings-14.pb
new file mode 100644
index 0000000..e3ecaa0
--- /dev/null
+++ b/src/src/build/sonar/scanner-report/syntax-highlightings-14.pb
@@ -0,0 +1,23 @@
+
+
+
+
+
+
+
+
+$ +
+
+
+
+
+1 E
+
+
+
+
+
+
+
+
+
\ No newline at end of file
diff --git a/src/src/build/sonar/scanner-report/syntax-highlightings-140.pb b/src/src/build/sonar/scanner-report/syntax-highlightings-140.pb
new file mode 100644
index 0000000..b27b253
--- /dev/null
+++ b/src/src/build/sonar/scanner-report/syntax-highlightings-140.pb
@@ -0,0 +1,23 @@
+
+
+
+
+
+
+ $
+$ &
+
+
+
+
+ @
+@ A
+
+
+
+ -
+. ;
+< U
+U X
+
+
\ No newline at end of file
diff --git a/src/src/build/sonar/scanner-report/syntax-highlightings-141.pb b/src/src/build/sonar/scanner-report/syntax-highlightings-141.pb
new file mode 100644
index 0000000..816c754
--- /dev/null
+++ b/src/src/build/sonar/scanner-report/syntax-highlightings-141.pb
@@ -0,0 +1,36 @@
+
+
+
+
+
+
+ $
+$ &
+
+
+
+
+ >
+> ?
+
+
+
+
+ )
+
+ *
+
+ .
+. 1
+
+
+
+
+ +
+
+ ,
+
+ .
+. 1
+
+
\ No newline at end of file
diff --git a/src/src/build/sonar/scanner-report/syntax-highlightings-142.pb b/src/src/build/sonar/scanner-report/syntax-highlightings-142.pb
new file mode 100644
index 0000000..5a091d0
--- /dev/null
+++ b/src/src/build/sonar/scanner-report/syntax-highlightings-142.pb
@@ -0,0 +1,22 @@
+
+
+
+
+
+
+ $
+$ &
+
+
+
+
+ >
+> ?
+
+
+ '
+
+ 1
+1 3
+
+
\ No newline at end of file
diff --git a/src/src/build/sonar/scanner-report/syntax-highlightings-15.pb b/src/src/build/sonar/scanner-report/syntax-highlightings-15.pb
new file mode 100644
index 0000000..d08f490
--- /dev/null
+++ b/src/src/build/sonar/scanner-report/syntax-highlightings-15.pb
@@ -0,0 +1,23 @@
+
+
+
+
+
+
+
+
+% ,
+
+
+
+
+1 E
+
+
+
+
+
+
+
+
+
\ No newline at end of file
diff --git a/src/src/build/sonar/scanner-report/syntax-highlightings-153.pb b/src/src/build/sonar/scanner-report/syntax-highlightings-153.pb
new file mode 100644
index 0000000..89c9a4f
--- /dev/null
+++ b/src/src/build/sonar/scanner-report/syntax-highlightings-153.pb
@@ -0,0 +1,49 @@
+
+
+
+
+
+
+ $
+$ &
+
+
+
+
+
+
+
+
+
+ 1
+1 2
+
+
+
+ 9
+
+
+
+ >
+
+
+
+ 7
+
+
+
+ :
+
+
+
+ (
+( )
+
+
+
+
+
+
+
+
+
\ No newline at end of file
diff --git a/src/src/build/sonar/scanner-report/syntax-highlightings-154.pb b/src/src/build/sonar/scanner-report/syntax-highlightings-154.pb
new file mode 100644
index 0000000..632c2f8
--- /dev/null
+++ b/src/src/build/sonar/scanner-report/syntax-highlightings-154.pb
@@ -0,0 +1,22 @@
+
+
+
+
+
+
+ $
+$ &
+
+
+
+
+
+
+
+
+
+ &
+& '
+0 8
+
+
\ No newline at end of file
diff --git a/src/src/build/sonar/scanner-report/syntax-highlightings-155.pb b/src/src/build/sonar/scanner-report/syntax-highlightings-155.pb
new file mode 100644
index 0000000..bd766b5
--- /dev/null
+++ b/src/src/build/sonar/scanner-report/syntax-highlightings-155.pb
@@ -0,0 +1,46 @@
+
+
+
+
+
+
+ $
+$ &
+
+
+
+
+
+
+
+
+
+ &
+& '
++ 3
+
+
+
+ &
+& '
++ 3
+
+
+
+ '
+' (
+, 4
+
+
+
+ '
+' (
+, 4
+
+
+
+ &
+& '
++ 3
+
+
\ No newline at end of file
diff --git a/src/src/build/sonar/scanner-report/syntax-highlightings-156.pb b/src/src/build/sonar/scanner-report/syntax-highlightings-156.pb
new file mode 100644
index 0000000..5593609
--- /dev/null
+++ b/src/src/build/sonar/scanner-report/syntax-highlightings-156.pb
@@ -0,0 +1,707 @@
+
+
+
+
+
+
+ $
+$ &
+
+
+
+
+
+ E
+
+ 7
+7 8
+
+
+ "
+" #
+3 <
+
+
+ %
+% &
+D M
+
+
+ $
+$ %
+8 A
+
+
+ "
+" #
+8 A
+
+
+
+
+( 1
+
+
+
+
+( 1
+
+
+
+
+" +
+
+
+
+
+* 3
+
+
+ "
+" #
+< E
+
+
+
+
+! *
+
+
+
+ !
+* 3
+
+
+
+ !
+ * 3
+!!
+!!
+!! )
+!!) *
+!!d m
+""
+""
+"" *
+""* +
+""P Y
+##
+##
+## '
+##' (
+##+ 4
+$$
+$$
+$$ $
+$$$ %
+$$- 6
+%%
+%%
+%% -
+%%- .
+%%J S
+&&
+&&
+&& *
+&&* +
+&&7 @
+''
+''
+'' %
+''% &
+''- 6
+((
+((
+(( "
+((" #
+((+ 4
+))
+))
+)) '
+))' (
+))2 ;
+**
+**
+**
+**
+**& /
+++
+++
+++ "
+++" #
+++. 7
+,,
+,,
+,,
+,, !
+,,% .
+--
+--
+-- "
+--" #
+--- 6
+..
+..
+..
+.. !
+..+ 4
+//
+//
+// "
+//" #
+//+ 4
+00 )
+11
+11
+11
+11
+11) 2
+22
+22
+22 '
+22' (
+224 =
+33
+44
+44
+44 ,
+44, -
+441 :
+55
+55
+55 %
+55% &
+550 9
+66
+66
+66 #
+66# $
+66/ 8
+77
+77
+77
+77
+77! *
+88
+88
+88 #
+88# $
+882 ;
+99
+99
+99
+99
+99( 1
+::
+::
+::
+::
+::% .
+;;
+;;
+;;
+;;
+;;% .
+<<
+<<
+<<
+<<
+<<+ 4
+==
+==
+== $
+==$ %
+==0 9
+>>
+>>
+>> #
+>># $
+>>N W
+??
+??
+?? "
+??" #
+??- 6
+@@
+@@
+@@ $
+@@$ %
+@@1 :
+AA
+AA
+AA !
+AA! "
+AA+ 4
+BB
+BB
+BB "
+BB" #
+BB( 1
+CC
+CC
+CC #
+CC# $
+CC* 3
+DD
+DD
+DD "
+DD" #
+DD( 1
+EE
+EE
+EE "
+EE" #
+EE( 1
+FF
+FF
+FF !
+FF! "
+FF2 ;
+GG
+GG
+GG #
+GG# $
+GG4 =
+HH
+HH
+HH #
+HH# $
+HH/ 8
+II
+II
+II %
+II% &
+II3 <
+JJ
+JJ
+JJ *
+JJ* +
+JJ= F
+KK
+KK
+KK
+KK
+KKD M
+LL
+LL
+LL
+LL
+LL# ,
+MM
+MM
+MM '
+MM' (
+MM4 =
+NN
+NN
+NN
+NN
+NN' 0
+OO
+OO
+OO %
+OO% &
+OO5 >
+PP
+PP
+PP +
+PP+ ,
+PP9 B
+QQ
+QQ
+QQ *
+QQ* +
+QQ8 A
+RR
+RR
+RR *
+RR* +
+RR= F
+SS
+SS
+SS .
+SS. /
+SSV _
+TT
+TT
+TT %
+TT% &
+TT; D
+UU
+UU
+UU -
+UU- .
+UUV _
+VV
+VV
+VV ,
+VV, -
+VVI R
+WW
+WW
+WW .
+WW. /
+WW\ e
+XX
+YY
+YY
+YY )
+YY) *
+YYI R
+ZZ
+ZZ
+ZZ &
+ZZ& '
+ZZJ S
+[[
+[[
+[[ '
+[[' (
+[[= F
+\\
+\\
+\\ -
+\\- .
+\\T ]
+]]
+]]
+]] 7
+]]7 8
+]]b k
+^^
+^^
+^^ (
+^^( )
+^^: C
+__
+__
+__ '
+__' (
+__3 <
+``
+``
+`` 0
+``0 1
+``_ h
+aa
+bb
+bb
+bb !
+bb! "
+bb2 ;
+cc
+cc
+cc !
+cc! "
+cc4 =
+dd
+dd
+dd
+dd
+dd- 6
+ee
+ee
+ee
+ee !
+ee1 :
+ff
+ff
+ff '
+ff' (
+ffL U
+gg
+gg
+gg %
+gg% &
+gg\ e
+hh
+hh
+hh &
+hh& '
+hhI R
+ii
+ii
+ii '
+ii' (
+ii8 A
+jj
+jj
+jj &
+jj& '
+jj; D
+kk
+kk
+kk *
+kk* +
+kkF O
+ll
+ll
+ll (
+ll( )
+llT ]
+mm
+nn
+nn
+nn $
+nn$ %
+nn- 6
+oo
+oo
+oo ,
+oo, -
+oo9 B
+pp
+pp
+pp .
+pp. /
+ppJ S
+qq
+qq
+qq -
+qq- .
+qqA J
+rr
+rr
+rr 4
+rr4 5
+rrH Q
+ss
+ss
+ss *
+ss* +
+ss6 ?
+tt
+tt
+tt 2
+tt2 3
+ttF O
+uu
+uu
+uu 2
+uu2 3
+uuF O
+vv
+vv
+vv *
+vv* +
+vv1 :
+ww
+ww
+ww 6
+ww6 7
+wwG P
+xx
+xx
+xx 1
+xx1 2
+xx@ I
+yy
+yy
+yy :
+yy: ;
+yyO X
+zz
+zz
+zz =
+zz= >
+
+zz
+{{
+{{
+{{ :
+{{: ;
+{{E N
+||
+||
+|| 9
+||9 :
+
+||
+}}
+}}
+}} :
+}}: ;
+}}p y
+~~
+~~
+~~ 7
+~~7 8
+~~] f
+
+
+ 5
+5 6
+V _
+
+
+
+
+
+
+
+ !
+
+' 0
+
+
+
+
+
+ *
+
+* +
+
+5 >
+
+
+
+
+
+ "
+
+" #
+
+- 6
+
+
+
+
+
+
+
+
+
+/ 8
+
+
+
+
+
+
+
+
+
++ 4
+
+
+
+
+
+ -
+
+- .
+
+@ I
+
+
+
+
+
+
+
+
+
+ (
+
+
+
+
+
+ %
+
+% &
+
+) 2
+
+
+
+
+
+ )
+
+) *
+
+0 9
+
+
+
+
+
+ (
+
+( )
+
+
+
+
+
+
+
+
+
+ &
+
+' )
+
+* 2
+
+3 :
+
+; >
+
+> ?
+
+C M
+
+[ c
+
+d f
+
+g o
+
+p w
+
+x }
+
+} ~
+
+
+
+ 0
+
+
+
+
+
+
+
+
+
+ '
+
+( *
+
++ 3
+
+4 ;
+
+< @
+
+@ A
+
+E O
+
+^ f
+
+g i
+
+j r
+
+s z
+{
+
+
+
+
+
+
\ No newline at end of file
diff --git a/src/src/build/sonar/scanner-report/syntax-highlightings-157.pb b/src/src/build/sonar/scanner-report/syntax-highlightings-157.pb
new file mode 100644
index 0000000..9a3ec2c
--- /dev/null
+++ b/src/src/build/sonar/scanner-report/syntax-highlightings-157.pb
@@ -0,0 +1,187 @@
+
+
+
+
+
+
+ $
+$ &
+
+
+
+
+
+
+
+
+
+ %
+% &
+
+
+ %
+% &
+A H
+
+
+ *
+* +
+2 9
+
+
+
+
+ %
+% &
+
+
+ %
+% &
+A H
+
+
+ *
+* +
+2 9
+
+
+
+
+ &
+& '
+
+
+ %
+% &
+B I
+
+
+ *
+* +
+2 9
+
+
+
+
+ &
+& '
+
+
+ %
+ % &
+ B I
+!!
+!!
+!! *
+!!* +
+!!2 9
+""
+$$
+
+$$
+$$ +
+$$+ ,
+%%
+%%
+%% %
+%%% &
+%%B I
+&&
+&&
+&& &
+&&& '
+&&? F
+''
+))
+
+))
+)) -
+))- .
+**
+**
+** %
+**% &
+**A H
+++
+++
+++ &
+++& '
+++A H
+,,
+..
+
+..
+.. -
+..- .
+//
+//
+// %
+//% &
+//B I
+00
+00
+00 &
+00& '
+00; B
+11
+33
+
+33
+33 0
+330 1
+44
+44
+
+44 !
+44! "
+44> E
+55
+55
+55 &
+55& '
+55? F
+66
+88
+
+88
+88 2
+882 3
+99
+99
+99 %
+99% &
+99A H
+::
+::
+:: &
+::& '
+::A H
+;;
+==
+
+==
+==
+== "
+==# D
+==D E
+>>
+>>
+>> +
+>>+ ,
+>>E L
+??
+AA
+
+AA
+AA $
+AA% +
+AA, ^
+AA^ _
+BB
+BB
+BB '
+BB' (
+BB/ 6
+CC
+
+DD
\ No newline at end of file
diff --git a/src/src/build/sonar/scanner-report/syntax-highlightings-158.pb b/src/src/build/sonar/scanner-report/syntax-highlightings-158.pb
new file mode 100644
index 0000000..eaf3c97
--- /dev/null
+++ b/src/src/build/sonar/scanner-report/syntax-highlightings-158.pb
@@ -0,0 +1,27 @@
+
+
+
+
+
+
+ $
+$ &
+
+
+
+
+
+
+
+
+ (
+( )
+
+
+
+
+
+
+
+
+
\ No newline at end of file
diff --git a/src/src/build/sonar/scanner-report/syntax-highlightings-159.pb b/src/src/build/sonar/scanner-report/syntax-highlightings-159.pb
new file mode 100644
index 0000000..3b9c485
--- /dev/null
+++ b/src/src/build/sonar/scanner-report/syntax-highlightings-159.pb
@@ -0,0 +1,634 @@
+
+
+
+
+
+
+ $
+$ &
+
+
+
+
+
+ E
+
+ 7
+7 8
+ #
+
+
+ "
+" #
+* 3
+
+
+ %
+% &
+. 7
+
+
+ $
+$ %
++ 4
+
+
+ "
+" #
+) 2
+
+
+
+
+ '
+
+
+
+
+" +
+
+
+
+
+ %
+
+
+
+
+& /
+
+
+ "
+" #
+) 2
+ #
+!!
+!!
+!!
+!!
+!! '
+""
+""
+""
+"" !
+""& /
+##
+##
+##
+## !
+##& /
+$$
+$$
+$$ )
+$$) *
+$$8 A
+%%
+%%
+%% *
+%%* +
+%%8 A
+&&
+&&
+&& '
+&&' (
+&&+ 4
+''
+''
+'' $
+''$ %
+'') 2
+((
+((
+(( -
+((- .
+((4 =
+))
+))
+)) *
+))* +
+))/ 8
+**
+**
+** %
+**% &
+**) 2
+++
+++
+++ "
+++" #
++++ 4
+,,
+,,
+,, '
+,,' (
+,,4 =
+--
+--
+--
+--
+--# ,
+..
+..
+.. "
+.." #
+..% .
+//
+//
+//
+// !
+//% .
+00
+00
+00 "
+00" #
+00' 0
+11
+11
+11
+11 !
+11% .
+22
+22
+22 "
+22" #
+22' 0
+33
+44
+44
+44 %
+44% &
+44+ 4
+55
+55
+55 #
+55# $
+55( 1
+66
+66
+66
+66
+66 (
+77
+77
+77 #
+77# $
+77( 1
+88
+88
+88
+88
+88" +
+99
+99
+99
+99
+99! *
+::
+::
+::
+::
+::! *
+;;
+;;
+;;
+;;
+;;# ,
+<<
+<<
+<< $
+<<$ %
+<<- 6
+==
+==
+== #
+==# $
+==. 7
+>>
+>>
+>> "
+>>" #
+>>% .
+??
+??
+?? $
+??$ %
+??) 2
+@@
+@@
+@@ !
+@@! "
+@@& /
+AA
+AA
+AA "
+AA" #
+AA$ -
+BB
+BB
+BB #
+BB# $
+BB& /
+CC
+CC
+CC "
+CC" #
+CC$ -
+DD
+DD
+DD "
+DD" #
+DD% .
+EE
+EE
+EE !
+EE! "
+EE( 1
+FF
+FF
+FF #
+FF# $
+FF* 3
+GG
+GG
+GG #
+GG# $
+GG) 2
+HH
+HH
+HH %
+HH% &
+HH+ 4
+II
+II
+II *
+II* +
+II2 ;
+JJ
+JJ
+JJ
+JJ
+JJ2 ;
+KK
+KK
+KK
+KK
+KK )
+LL
+LL
+LL '
+LL' (
+LL- 6
+MM
+MM
+MM
+MM
+MM! *
+NN
+NN
+NN %
+NN% &
+NN* 3
+OO
+OO
+OO +
+OO+ ,
+OO1 :
+PP
+PP
+PP *
+PP* +
+PP1 :
+QQ
+QQ
+QQ *
+QQ* +
+QQ1 :
+RR
+RR
+RR %
+RR% &
+RR( 1
+SS
+SS
+SS -
+SS- .
+SS? H
+TT
+TT
+TT ,
+TT, -
+TT8 A
+UU
+UU
+UU .
+UU. /
+UU? H
+VV
+VV
+VV .
+VV. /
+VVG P
+WW
+XX
+XX
+XX )
+XX) *
+XX5 >
+YY
+YY
+YY &
+YY& '
+YY7 @
+ZZ
+ZZ
+ZZ '
+ZZ' (
+ZZ1 :
+[[
+[[
+[[ -
+[[- .
+[[: C
+\\
+\\
+\\ 7
+\\7 8
+\\C L
+]]
+]]
+]] (
+]]( )
+]]- 6
+^^
+^^
+^^ '
+^^' (
+^^, 5
+__
+__
+__ 0
+__0 1
+__K T
+``
+aa
+aa
+aa !
+aa! "
+aa) 2
+bb
+bb
+bb !
+bb! "
+bb& /
+cc
+cc
+cc
+cc
+cc# ,
+dd
+dd
+dd
+dd !
+dd& /
+ee
+ee
+ee '
+ee' (
+ee1 :
+ff
+ff
+ff %
+ff% &
+ff5 >
+gg
+gg
+gg &
+gg& '
+gg2 ;
+hh
+hh
+hh '
+hh' (
+hh- 6
+ii
+ii
+ii &
+ii& '
+ii0 9
+jj
+jj
+jj *
+jj* +
+jj9 B
+kk
+kk
+kk (
+kk( )
+kk4 =
+ll
+mm
+mm
+mm $
+mm$ %
+mm' 0
+nn
+nn
+nn ,
+nn, -
+nn1 :
+oo
+oo
+oo .
+oo. /
+ooA J
+pp
+pp
+pp -
+pp- .
+pp8 A
+qq
+qq
+qq *
+qq* +
+qq/ 8
+rr
+rr
+rr 2
+rr2 3
+rr7 @
+ss
+ss
+ss 2
+ss2 3
+ss7 @
+tt
+tt
+tt *
+tt* +
+tt- 6
+uu
+uu
+uu 6
+uu6 7
+uu; D
+vv
+vv
+vv 1
+vv1 2
+vv6 ?
+ww
+ww
+ww :
+ww: ;
+wwD M
+xx
+xx
+xx =
+xx= >
+xxd m
+yy
+yy
+yy :
+yy: ;
+yy? H
+zz
+zz
+zz 9
+zz9 :
+zz^ g
+{{
+{{
+{{ :
+{{: ;
+{{I R
+||
+||
+|| 7
+||7 8
+||D M
+}}
+}}
+}} 5
+}}5 6
+}}@ I
+~~
+~~
+~~
+~~ !
+~~# ,
+
+
+ *
+* +
+/ 8
+
+
+
+
+
+ "
+
+" #
+
+( 1
+
+
+
+
+
+
+
+
+
+& /
+
+
+
+
+
+
+
+
+
+# ,
+
+
+
+
+
+ -
+
+- .
+
+4 =
+
+
+
+
+
+
+
+
+
+ %
+
+
+
+
+
+ %
+
+% &
+
+( 1
+
+
+
+
+
+ )
+
+) *
+
+, 5
+
+
+
+
+
+ (
+
+( )
+
+
+
+
+
+
+
+
+
+ '
+
+( *
+
++ 3
+
+3 4
+
+8 B
+
+G O
+
+P R
+
+S [
+
+[ \
+
+` j
+
+p w
+
+
+
\ No newline at end of file
diff --git a/src/src/build/sonar/scanner-report/syntax-highlightings-16.pb b/src/src/build/sonar/scanner-report/syntax-highlightings-16.pb
new file mode 100644
index 0000000..9d73c88
--- /dev/null
+++ b/src/src/build/sonar/scanner-report/syntax-highlightings-16.pb
@@ -0,0 +1,102 @@
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ #
+""
+""
+""
+""4 ;
+$$
+
+$$
+%%
+((
+**
+,,
+..
+00
+
+88
+
+88
+<<
+
+<<
+==
+BB
+BB
+BB" %
+CC$ '
+HH
+
+II@ A
+IIC F
+JJ, 1
+JJ4 5
+LL
+
+MM@ A
+MMC F
+NN& +
+NN. /
+P^ !
+bb
+cc
+ff
+ff+ /
+ii
+jj
+jj
+kk; <
+ll
+
+ll
+mmA B
+qq
+rr
+rr
+ss
+
+ww
+
+ww
+yy
+
+yy
+{{
+
+{{
+
+
+# '
+
+
+
+
+
+
+
+
\ No newline at end of file
diff --git a/src/src/build/sonar/scanner-report/syntax-highlightings-160.pb b/src/src/build/sonar/scanner-report/syntax-highlightings-160.pb
new file mode 100644
index 0000000..eaf3c97
--- /dev/null
+++ b/src/src/build/sonar/scanner-report/syntax-highlightings-160.pb
@@ -0,0 +1,27 @@
+
+
+
+
+
+
+ $
+$ &
+
+
+
+
+
+
+
+
+ (
+( )
+
+
+
+
+
+
+
+
+
\ No newline at end of file
diff --git a/src/src/build/sonar/scanner-report/syntax-highlightings-161.pb b/src/src/build/sonar/scanner-report/syntax-highlightings-161.pb
new file mode 100644
index 0000000..ab7b969
--- /dev/null
+++ b/src/src/build/sonar/scanner-report/syntax-highlightings-161.pb
@@ -0,0 +1,532 @@
+
+
+
+
+
+
+ $
+$ &
+
+
+
+
+
+ E
+
+ 7
+7 8
+
+
+
+
+ '
+
+
+
+ !
+& /
+
+
+
+ !
+& /
+
+
+ )
+) *
+8 A
+
+
+ *
+* +
+8 A
+
+
+ '
+' (
++ 4
+
+
+ $
+$ %
+) 2
+
+
+ -
+- .
+4 =
+
+
+ *
+* +
+/ 8
+
+
+ %
+% &
+) 2
+
+
+ "
+" #
++ 4
+
+
+ '
+' (
+4 =
+
+
+
+
+ # ,
+!!
+!!
+!! "
+!!" #
+!!% .
+""
+""
+""
+"" !
+""% .
+##
+##
+## "
+##" #
+##' 0
+$$
+$$
+$$
+$$ !
+$$% .
+%%
+%%
+%% "
+%%" #
+%%' 0
+&&
+&&
+&& .
+&&. /
+&&F O
+''
+((
+((
+(( %
+((% &
+((+ 4
+))
+))
+)) #
+))# $
+))( 1
+**
+**
+**
+**
+** (
+++
+++
+++ #
+++# $
+++( 1
+,,
+,,
+,,
+,,
+,," +
+--
+--
+--
+--
+--! *
+..
+..
+..
+..
+..! *
+//
+//
+//
+//
+//# ,
+00
+00
+00 $
+00$ %
+00- 6
+11
+11
+11 #
+11# $
+11. 7
+22
+22
+22 "
+22" #
+22% .
+33
+33
+33 $
+33$ %
+33) 2
+44
+44
+44 !
+44! "
+44& /
+55
+55
+55 "
+55" #
+55$ -
+66
+66
+66 #
+66# $
+66& /
+77
+77
+77 "
+77" #
+77$ -
+88
+88
+88 "
+88" #
+88% .
+99
+99
+99 !
+99! "
+99( 1
+::
+::
+:: #
+::# $
+::* 3
+;;
+;;
+;; #
+;;# $
+;;) 2
+<<
+<<
+<< %
+<<% &
+<<+ 4
+==
+==
+== *
+==* +
+==2 ;
+>>
+>>
+>>
+>>
+>>2 ;
+??
+??
+??
+??
+?? )
+@@
+@@
+@@ '
+@@' (
+@@- 6
+AA
+AA
+AA
+AA
+AA! *
+BB
+BB
+BB %
+BB% &
+BB* 3
+CC
+CC
+CC +
+CC+ ,
+CC1 :
+DD
+DD
+DD *
+DD* +
+DD1 :
+EE
+EE
+EE *
+EE* +
+EE1 :
+FF
+FF
+FF %
+FF% &
+FF( 1
+GG
+GG
+GG -
+GG- .
+GG? H
+HH
+HH
+HH ,
+HH, -
+HH8 A
+II
+II
+II .
+II. /
+II> G
+JJ
+JJ
+JJ )
+JJ) *
+JJ5 >
+KK
+KK
+KK &
+KK& '
+KK8 A
+LL
+LL
+LL '
+LL' (
+LL1 :
+MM
+MM
+MM -
+MM- .
+MM: C
+NN
+NN
+NN 7
+NN7 8
+NNC L
+OO
+OO
+OO (
+OO( )
+OO- 6
+PP
+PP
+PP '
+PP' (
+PP, 5
+QQ
+QQ
+QQ 0
+QQ0 1
+QQJ S
+RR
+SS
+SS
+SS !
+SS! "
+SS) 2
+TT
+TT
+TT !
+TT! "
+TT& /
+UU
+UU
+UU
+UU
+UU# ,
+VV
+VV
+VV
+VV !
+VV& /
+WW
+WW
+WW '
+WW' (
+WW1 :
+XX
+XX
+XX %
+XX% &
+XX5 >
+YY
+YY
+YY &
+YY& '
+YY2 ;
+ZZ
+ZZ
+ZZ '
+ZZ' (
+ZZ- 6
+[[
+[[
+[[ &
+[[& '
+[[0 9
+\\
+\\
+\\ *
+\\* +
+\\9 B
+]]
+]]
+]] (
+]]( )
+]]4 =
+^^
+__
+__
+__ $
+__$ %
+__' 0
+``
+``
+`` ,
+``, -
+``1 :
+aa
+aa
+aa .
+aa. /
+aaA J
+bb
+bb
+bb -
+bb- .
+bb8 A
+cc
+cc
+cc *
+cc* +
+cc/ 8
+dd
+dd
+dd 2
+dd2 3
+dd7 @
+ee
+ee
+ee 2
+ee2 3
+ee7 @
+ff
+ff
+ff *
+ff* +
+ff- 6
+gg
+gg
+gg 6
+gg6 7
+gg; D
+hh
+hh
+hh 1
+hh1 2
+hh6 ?
+ii
+ii
+ii :
+ii: ;
+iiD M
+jj
+jj
+jj =
+jj= >
+jjd m
+kk
+kk
+kk :
+kk: ;
+kk? H
+ll
+ll
+ll 9
+ll9 :
+ll^ g
+mm
+mm
+mm :
+mm: ;
+mmI R
+nn
+nn
+nn 7
+nn7 8
+nnD M
+oo
+oo
+oo 5
+oo5 6
+oo@ I
+qq
+qq
+qq
+qq !
+qq# ,
+rr
+rr
+rr *
+rr* +
+rr/ 8
+ss
+ss
+ss "
+ss" #
+ss( 1
+uu
+uu
+uu
+uu
+uu& /
+vv
+vv
+vv
+vv
+vv# ,
+ww
+ww
+ww -
+ww- .
+ww4 =
+xx
+xx
+xx
+xx
+xx %
+yy
+yy
+yy %
+yy% &
+yy( 1
+zz
+zz
+zz )
+zz) *
+zz, 5
+{{
+{{
+{{ (
+{{( )
+||
+||
+||
+||
+|| '
+||( *
+||+ 3
+||3 4
+||8 B
+||G O
+||P R
+||S [
+||[ \
+||` j
+||p w
+}}
+
+
\ No newline at end of file
diff --git a/src/src/build/sonar/scanner-report/syntax-highlightings-162.pb b/src/src/build/sonar/scanner-report/syntax-highlightings-162.pb
new file mode 100644
index 0000000..2df0aa5
--- /dev/null
+++ b/src/src/build/sonar/scanner-report/syntax-highlightings-162.pb
@@ -0,0 +1,32 @@
+
+
+
+
+
+
+ $
+$ &
+
+
+
+
+ >
+> ?
+
+
+ +
++ ,
+
+
+
+
+
+ 3
+
+ F
+
+! (
+( +
+
+
+
\ No newline at end of file
diff --git a/src/src/build/sonar/scanner-report/syntax-highlightings-163.pb b/src/src/build/sonar/scanner-report/syntax-highlightings-163.pb
new file mode 100644
index 0000000..27ccd51
--- /dev/null
+++ b/src/src/build/sonar/scanner-report/syntax-highlightings-163.pb
@@ -0,0 +1,28 @@
+
+
+
+
+
+
+ $
+$ &
+
+
+
+
+ >
+
+ (
+
+ &
+
+ -
+ "
+# *
+ %
+& B
+ %
+& J
+ !
+" (
+( +
\ No newline at end of file
diff --git a/src/src/build/sonar/scanner-report/syntax-highlightings-164.pb b/src/src/build/sonar/scanner-report/syntax-highlightings-164.pb
new file mode 100644
index 0000000..d7f3e19
--- /dev/null
+++ b/src/src/build/sonar/scanner-report/syntax-highlightings-164.pb
@@ -0,0 +1,22 @@
+
+
+
+
+
+
+ $
+$ &
+
+
+
+
+ >
+
+ -
+
+
+
+
+
+
+
\ No newline at end of file
diff --git a/src/src/build/sonar/scanner-report/syntax-highlightings-165.pb b/src/src/build/sonar/scanner-report/syntax-highlightings-165.pb
new file mode 100644
index 0000000..d7f3e19
--- /dev/null
+++ b/src/src/build/sonar/scanner-report/syntax-highlightings-165.pb
@@ -0,0 +1,22 @@
+
+
+
+
+
+
+ $
+$ &
+
+
+
+
+ >
+
+ -
+
+
+
+
+
+
+
\ No newline at end of file
diff --git a/src/src/build/sonar/scanner-report/syntax-highlightings-17.pb b/src/src/build/sonar/scanner-report/syntax-highlightings-17.pb
new file mode 100644
index 0000000..f498dc3
--- /dev/null
+++ b/src/src/build/sonar/scanner-report/syntax-highlightings-17.pb
@@ -0,0 +1,903 @@
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+!!
+
+""
+
+##
+
+%%
+
+&&
+
+''
+
+((
+
+))
+
+**
+
+++
+
+,,
+
+--
+
+..
+
+//
+
+00
+
+11
+
+22
+
+33
+
+44
+
+55
+
+77
+
+88
+
+99
+
+::
+
+;;
+
+<<
+
+==
+
+>>
+
+??
+
+BB
+BB
+CC
+CC
+CC
+CC2 7
+EE
+EE
+EE
+EE, L
+GG
+GG
+GG
+GG0 R
+II
+II
+II
+II1 U
+KK
+KK
+KK+ /
+MM
+OO
+QQ
+SS
+SS
+UU
+UU
+WW
+WW
+YY
+YY
+[[
+]]
+__
+``
+cc
+dd
+ee
+ff
+gg
+hh
+kk
+
+kk
+kk
+ll
+
+ll
+mm
+oo
+rr
+
+rr
+ss B
+tt #
+uu
+uu
+vv
+vv
+ww
+ww
+xx
+xx
+yy
+
+zz
+}} 0
+~~
+
+
+
+
+
+
+
+ *
+
+
+
+
+
+8 =
+
+
+
+
+
+
+ 4
+
+
+
+
+
+ 0
+
+
+
+
+3 >
+
+ *
+
+ #
+
+D H
+
+
+
+. 1
+
+5 6
+
+ #
+
+' +
+
+( .
+
+
+
+
+
+ 0
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+9 @
+
+> J
+
+
+
+
+
+
+ =
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ T
+
+
+
+
+
+
+
+
+
+! %
+
+1 5
+
+7 ;
+
+
+
+
+
+3 ?
+
+- 2
+
+
+
+
+ .
+
+
+
+
+
+
+
+
+
+
+
+
+ L
+
+ "
+
+5 9
+
+
+
+ !
+
+ 8
+
+
+
+
+
+
+
+ /
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ %
+
+
+
+ !
+
+$ '
+
+
+
+1 4
+
+I N
+
+
+
+
+
+( 0
+
+ !
+
+$ (
+
+ !
+
+
+
+$ )
+
+
+
+
+
+. 3
+
+$ (
+
+
+
+ B
+
+ %
+
+ &
+
+ (
+
+
+
+
+
+ "
+
+
+
+
+
+' (
+
+
+
+( +
+
+
+
+
+ "
+
+
+
+
+
+
+
+
+ *
+
+ 1
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ )
+
++ \
+
+
+
+! $
+
+
+
+
+
+
+
+9 ?
+
+! %
+
+
+
+
++ /
+
+ #
+
+
+
+
+ #
+
+H N
+
+
+
+
+
+
+
+
+& *
+
+O X
+
+ #
+
+- 1
+
+
+
+
+
+$ '
+
+V Y
+
+ "
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+2 8
+
+
+
+
+ +
+
+
+
+
+
+- <
+
+
+
+2 5
+
+
+
+, /
+
+* -
+
+I P
+
+
+
+
+
+
+
+
+
+
+ "
+
+
+
+
+
+. B
+
+
+
+
+ "
+
+
+
+
+
+. B
+
+
+
+
+ "
+
+
+
+
+
+- _
+
+
+
+
+ "
+
+
+
+
+
+- P
+
+
+
+
+
+
+& ,
+
+
+
+ #
+
+# &
+
+
+
+
+
+
+
+= >
+
+
+
+
+ "
+
+
+
+
+
+- U
+
+
+
+
+
+
+2 8
+
+
+
+ #
+
+# &
+
+
+
+
+
+
+
+= >
+
+
+
+
+ "
+
+
+
+
+
+- Y
+
+
+
+
+
+
+ %
+
+
+
+
+
+
+
+
+$ '
+
+
+
+ !
+
+ #
+
+
+
+ &
+
+
+
+
+
+1 [
+
+
+
+
+
+
+) /
+
+
+
+
+
+
+ ;
+
+ "
+
+
+
+ $
+
+@ B
+
+
+
+ $
+
+ "
+
+
+
+
+
+
+
+
+
+
+ #
+
+# &
+
+ #
+
+
+
+
+
+D H
+
+ P
+
+ *
+
+
+
+ E
+
+
+
+
+
+
+ "
+
+
+
+
+
+- S
+
+
+
+
+
+
+& ,
+
+
+
+ #
+
+# &
+
+
+
+
+
+
+
+
+
+
+
+
+ "
+
+
+
+
+
+- U
+
+
+
+
+$ *
+
+
+
+
+ +
+
+
+
+
+
+- <
+
+
+
+ !
+
+$ (
+
+
+
+ &
+
+ (
+
+
+
+
+
+ "
+
+
+
+
+
+' (
+
+
+
+
+
+$ '
+
+
+
+
+ "
+
+
+
+
+
+. L
+
+
+
+
+ "
+
+
+
+
+
+. L
+
+
+
+
+ "
+
+
+
+
+
+- Y
+
+
+
+
+1 7
+
+
+
+ #
+
+# &
+
+ #
+
+
+
+@ E
+
+
+
+
+
+
+
+
+ "
+
+
+
+
+
+- W
+
+
+
+
+
+
+
+
+
+
+
+
\ No newline at end of file
diff --git a/src/src/build/sonar/scanner-report/syntax-highlightings-18.pb b/src/src/build/sonar/scanner-report/syntax-highlightings-18.pb
new file mode 100644
index 0000000..fc4e502
--- /dev/null
+++ b/src/src/build/sonar/scanner-report/syntax-highlightings-18.pb
@@ -0,0 +1,966 @@
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+!!
+
+""
+
+##
+
+$$
+
+%%
+
+&&
+
+''
+
+))
+
+**
+
+++
+
+--
+
+..
+
+//
+
+00
+
+33
+33
+44
+44
+44
+443 8
+66
+
+66
+66
+66
+66, -
+88
+
+88
+88
+88
+882 3
+::
+
+::
+::
+::
+::3 4
+<<
+
+<<
+<<
+<<
+<<5 6
+>>
+
+>>
+>>
+>>
+>>3 4
+@@
+@@
+@@, 0
+BB
+DD
+FF
+HH
+HH
+JJ
+JJ
+LL
+NN
+PP
+RR
+TT
+VV
+XX
+ZZ
+[[
+\\
+]]
+^^
+__
+``
+aa
+bb
+cc
+ff
+
+ff
+ff
+gg
+
+gg
+hh
+jj
+mm
+
+mm
+mm
+nn %
+rr
+
+rr
+ss
+
+tt ,
+uu
+yy
+zz
+
+
+
+
+
+
+
+
+
+
+
+
+
+6 P
+
+ ,
+
+ #
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ "
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+! '
+
+
+
+
+
+
+
+
+ #
+
+
+
+
+
+
+
+
+
+
+
+ #
+
+ %
+
+
+
+
+
+! "
+
+, /
+
+
+
+
+
+5 9
+
+ .
+
+
+
+ !
+
+
+
+
+
+
+
+
+
+
+
+
+
+( +
+
+ !
+
+
+
+
+
+! "
+
+$ '
+
+
+
+
+
+
+ "
+
+
+
+
+
+- W
+
+
+
+
+
+ %
+
+
+
+
+
+
+
+
+
+
+ !
+
+
+
+ /
+
+1 4
+
+
+
+
+
+
+
+
+
+
+
+ $
+
+
+
+ 9
+
+
+
+
+
+
+
+
+
+
+
+
+ (
+
+
+
+ /
+
+1 4
+
+* 1
+
+
+
+
+
+
+
+
+
+ $
+
+
+
+
+
+T U
+
+ (
+
+
+
+ ,
+
+
+
+ F
+
+
+
+
+
+
+
+
+
+
+ %
+
+
+
+
+
+@ D
+
+
+
+ @
+
+ N
+
+
+
+ #
+
+
+
+
+
+
+
+
+
+
+1 ]
+
+
+
+
+
+
+
+
+
+
+ $
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+D H
+
+J N
+
+P T
+
+
+
+
+
+
+
+
+
+( ,
+
+# '
+
+ N
+
+
+
+
+
+
+
+ 8
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+X a
+
+
+
+
+
+
+
+
+
+
+
+
+
+ $
+
+, 0
+
+' +
+
+ H
+
+ $
+
+
+
+
+
+
+
+ =
+
+
+
+
+
+
+
+
+
+
+ %
+
+
+
+ /
+
+1 4
+
+* 1
+
+
+
+
+
+
+
+
+
+ $
+
+
+
+
+
+T U
+
+ (
+
+
+
+ ,
+
+
+
+ <
+
+
+
+
+
+
+
+
+
+
+ !
+
+
+
+
+
+
+
+D H
+
+
+
+ C
+
+
+
+
+
+
+
+
+ "
+
+B H
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ ?
+
+ 9
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+1 J
+
+
+
+
+
+) /
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ P
+
+
+
+
+
+
+
+! "
+
+
+
+
+
+
+
+ O
+
+ ,
+
+
+
+ &
+
+
+
+
+
+ A
+
+
+
+
+
+1 H
+
+
+
+
+
+ !
+
+
+
+
+
+
+
+6 <
+
+
+
+
+
+
+ "
+
+
+
+ (
+
+
+
+
+
+
+
+
+ =
+
+
+
+
+
+- G
+
+
+
+
+
+
+
+
+
+4 :
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ !
+
+ ?
+
+
+
+
+
+1 I
+
+
+
+
+
+
+ $
+
+ ?
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ &
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+7 =
+
+
+
+
+
+
+
+
+
+
+
+
+ !
+
+
+
+
+
+
+ $
+
+ ?
+
+
+
+
+
+1 L
+
+
+
+ $
+
+
+
+
+
+
+
+? E
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+& ,
+
+
+
+
+
+
+ $
+
+
+
+
+
+ 0
+
+2 5
+
+* 1
+
+
+
+
+
+
+
+
+
+ $
+
+/ 2
+
+G K
+
+M Q
+
+
+
+# 8
+
+
+
+ !
+
+ L
+
+
+
+ J
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
\ No newline at end of file
diff --git a/src/src/build/sonar/scanner-report/syntax-highlightings-19.pb b/src/src/build/sonar/scanner-report/syntax-highlightings-19.pb
new file mode 100644
index 0000000..c6ec51d
--- /dev/null
+++ b/src/src/build/sonar/scanner-report/syntax-highlightings-19.pb
@@ -0,0 +1,150 @@
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ %
+
+
+
+
+4 F
+
+
+
+
+
+0 1
+
+
+
+
+
+1 2
+!!
+
+!!
+!!
+!!
+!!- .
+##
+
+##
+##
+##> p
+%%
+
+%%
+%%
+%%D O
+''
+
+''
+''
+''F S
+))
+))
+)). 2
+++
+++
+++* ,
+--
+--
+--
+--+ 6
+..
+
+..
+//
+//+ /
+//1 4
+00
+00 #
+00$ (
+11 $
+22" $
+66
+;;
+;;
+<<
+
+<<
+AA
+BB
+
+BB
+BB
+CC
+FF
+GG
+
+GG
+GG- 0
+GG8 ;
+II
+
+II
+JJ
+KK
+MM
+NN
+PP
+QQ
+RR
+TT
+VV
+VV
+YY
+ZZ
+
+ZZ
+[[
+
+[[
+``
+
+aa
+aa
+dd
+
+dd
+dd
+ff
+ggI M
+ll
+
+ll
+ll
+nn
+nn> C
+ss
+
+ss
+ss
+tt
+tt= B
+yy
+
+yy
+yy
+zz
+zz
+}}
+
+}}
+~~
\ No newline at end of file
diff --git a/src/src/build/sonar/scanner-report/syntax-highlightings-20.pb b/src/src/build/sonar/scanner-report/syntax-highlightings-20.pb
new file mode 100644
index 0000000..bf050b5
--- /dev/null
+++ b/src/src/build/sonar/scanner-report/syntax-highlightings-20.pb
@@ -0,0 +1,313 @@
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+""
+
+%%
+%%
+&&
+''
+((
+((
+((
+((& ,
+)+
+,,
+
+,,
+,,
+,, #
+,,B F
+-- ,
+.. "
+//
+33/ 0
+77
+77
+88
+99< =
+::
+
+;; ,
+<<
+>>
+
+>>
+??
+??
+??, <
+AA
+DD
+
+EE
+FF
+II
+
+II
+II8 A
+KK8 9
+OO
+
+OO
+SS
+
+SS
+SS "
+WW
+
+WW
+XX
+[[
+
+[[
+[[ "
+__
+
+__
+cc
+
+cc
+dd
+dd( )
+gg
+
+gg
+gg- 1
+hh
+
+hh
+ii
+ii
+ii/ ?
+ll
+
+mm
+mm
+pt
+uu
+
+vv] a
+ww
+ww
+xx =
+yy *
+}}
+
+~~J N
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+* 4
+
+
+
+ !
+
+ !
+
+
+
+
+
+
+
+
+
+, -
+
+J K
+
+
+
+
+
+
+
+
+
+
+
+
+
+3 V
+
+
+
+
+
+
+
+
+
+
+
+
+
+3 V
+
+
+
+< =
+
+
+
+< =
+
+W `
+
+5 9
+
+
+
+
+
+
+
+
+
+
+
+3 C
+
+@ C
+
+7 ;
+
+
+
+( )
+
+
+
+# $
+
+
+
+M N
+
+
+
+# J
+
+
+
+ #
+
+
+
+
+
+( )
+
+
+
+# $
+
+
+
+M N
+
+
+
+# J
+
+
+
+ #
+
+
+
+
+
+' (
+
+
+
+
+
+' +
+
+A B
+
+N O
+
+T X
+
+\ `
+
+
+
+- 5
+
+
+
+
+
+
+
+- 5
+
+
+
+
+
+
+
+
\ No newline at end of file
diff --git a/src/src/build/sonar/scanner-report/syntax-highlightings-21.pb b/src/src/build/sonar/scanner-report/syntax-highlightings-21.pb
new file mode 100644
index 0000000..8ed0a2f
--- /dev/null
+++ b/src/src/build/sonar/scanner-report/syntax-highlightings-21.pb
@@ -0,0 +1,555 @@
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+""
+
+%%
+%%
+&&
+''
+((
+))
+))
+**
+++
+,,
+--
+--
+//
+//
+11
+11
+33
+33
+55
+55
+77
+77
+99
+99
+;;
+==
+==
+==
+==& 3
+??
+??
+AA
+CC
+
+CC
+CC
+CC3 6
+MM
+
+MM
+MM
+MM3 6
+VV
+VV
+VV
+VV
+VV. /
+XX
+XX
+XX
+XX
+XX3 4
+ZZ
+ZZ
+ZZ
+ZZ
+ZZ5 6
+\\
+\\
+\\
+\\
+\\0 1
+^^
+^^
+^^
+^^
+^^5 6
+``
+``
+``
+``
+``8 9
+bb
+bb
+bb
+bb
+bb7 8
+dd
+dd
+dd
+dd
+dd5 6
+ff
+ff
+ff
+ff
+ff7 8
+hh
+hh
+hh
+hh
+hh9 :
+ll
+mm
+mm) -
+oo
+rr
+ss
+tt
+uu
+yy
+zz
+zz) -
+zz6 :
+~~
+
+
+
+
+
+
+^ b
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ )
+
+
+
+
+
+/ M
+
+
+
+
+
+& *
+
+, /
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+# ?
+
+
+
+
+
+
+ )
+
+
+
+
+
+/ T
+
+
+
+
+
+
+? C
+
+N Q
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+4 8
+
+
+
+
+
+, -
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+J K
+
+ >
+
+
+
+
+
+
+
+
+
+5 9
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ !
+
+( /
+
+
+
+
+
+
+
+* .
+
+
+
+
+
+
+ #
+
+
+
+
+^ b
+
+
+
+
+
+
+
+
+
+
+
+
+
+. 2
+
+
+
+
+
+
+! $
+
++ 2
+
+
+
+
+
+
+. 2
+
+
+
+
+
+
+ !
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+6 :
+
+
+
+
+
+
+
+
+
+
+! %
+
+( -
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+M P
+
+q u
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+1 3
+
+- /
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+! %
+
+, 3
+
+
+
+
+
+
+
+
+
+$ '
+
+1 4
\ No newline at end of file
diff --git a/src/src/build/sonar/scanner-report/syntax-highlightings-22.pb b/src/src/build/sonar/scanner-report/syntax-highlightings-22.pb
new file mode 100644
index 0000000..1c83ff7
--- /dev/null
+++ b/src/src/build/sonar/scanner-report/syntax-highlightings-22.pb
@@ -0,0 +1,464 @@
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+""
+
+##
+
+$$
+
+%%
+
+&&
+
+))
+))
+**
+**
+**
+**& 3
+++
+,,
+,,
+..
+
+..
+..
+//
+
+//
+00
+22
+58
+99 +
+::
+
+::
+::
+::
+::A B
+;;
+<<
+
+<<
+<<
+<<
+<<A B
+== F
+>>
+
+>>
+>>
+>>
+>>A B
+?? C
+@@
+
+@@
+@@
+@@
+@@A B
+AA
+BB
+
+BB
+BB
+BB
+BBA B
+DD
+FF
+GG
+JJ
+JJ
+JJ
+KK
+NN
+
+NN
+OO
+RR
+
+SS
+VV
+
+WW
+ZZ
+ZZ
+ZZ
+[[
+[[
+[[
+bb
+bb
+bb
+bb
+bb2 3
+dd
+dd
+dd
+dd
+dd= >
+ff
+ff
+ff
+ff
+ff7 8
+hh
+hh
+hh
+qq
+qq
+qq
+qq
+qq7 8
+ss
+ss
+ss
+ss
+ss9 :
+uu
+uu
+uu
+uu
+uu9 :
+ww
+ww
+ww
+ww
+ww< =
+yy
+yy
+zz
+zz
+zz
+zz
+zz? @
+{{
+{{
+{{
+{{
+{{? @
+||
+||
+||
+||
+||? @
+~~
+
+
+
+
+
+
+
+
+
+
+
+
+! $
+
+
+
+
+
+
+
+
+
+ 0
+
+= A
+
+C F
+
+
+
+
+
+ #
+
+
+
+
+
+ :
+
+ 9
+
+
+
+
+
+
+
+
+
+; ?
+
+A D
+
+
+
+
+
+ "
+
+
+
+
+
+
+
+ 1
+
+
+
+
+
+ .
+
+ =
+
+
+
+
+
+ !
+
+
+
+
+
+ 2
+
+
+
+
+
+ !
+
+
+
+
+
+
+
+
+
+
+
+ 2
+
+
+
+
+
+
+
+ 3
+
+
+
+ 0
+
+
+
+- 0
+
+G N
+
+6 :
+
+T [
+
+/ 2
+
+R V
+
+X \
+
+
+
+ $
+
+
+
+
+
+ .
+
+, .
+
+
+
+
+
+
+
+
+
+ ,
+
+' *
+
+@ G
+
+ "
+
+$ (
+
+* .
+
+
+
+ "
+
+
+
+
+
+ 9
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ ;
+
+
+
+
+
+ !
+
+
+
+' *
+
+
+
+
+
+ &
+
+ 9
+
+
+
+
+
+
+
+ &
+
+ 9
+
+
+
+
+
+
+
+ &
+
+ 9
+
+
+
+
+
+
+
+
+
+
+
+
+
+E H
+
+X [
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ Q
+
+
+
+ P
+
+
+
+
+
+
+ "
+
+ 6
+
+
+
+
+ "
+
+ 6
+
+
+
+
\ No newline at end of file
diff --git a/src/src/build/sonar/scanner-report/syntax-highlightings-23.pb b/src/src/build/sonar/scanner-report/syntax-highlightings-23.pb
new file mode 100644
index 0000000..f637c07
--- /dev/null
+++ b/src/src/build/sonar/scanner-report/syntax-highlightings-23.pb
@@ -0,0 +1,481 @@
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+""
+
+##
+
+&&
+&&
+''
+
+''
+''
+''% 0
+((
+
+((
+((
+))
+
+))
+** (
+++
+++
+--
+
+--
+.. 0
+//
+//
+22< ?
+33
+33
+44
+55 <
+66
+<<
+>>
+>>
+>>5 6
+>>B C
+>>H L
+?? 6
+@@
+@@
+BB
+BB
+CC
+
+DD% -
+EE
+
+FF% -
+HH
+HH
+KK
+
+KK
+KK
+KKA E
+KKJ N
+KK\ `
+LL "
+OO/ 0
+PPX \
+PP^ b
+SS
+
+SS
+SS
+TT
+UU
+
+UU
+VV (
+WW
+WW
+ZZ< ?
+[[
+[[
+__: ;
+cc
+ee
+ee
+ee5 6
+eeB C
+eeH L
+ff 6
+gg
+gg
+ii
+ii
+jj
+
+kk% -
+ll
+
+mm% -
+oo
+oo
+rt
+uu
+
+uu
+uu
+ww
+ww )
+xx# ,
+xxG L
+yy
+zz
+||
+||
+}}
+
+}}
+~~
+
+
+* +
+
+
+
+ 9
+
+
+
+
+
+
+
+
+
+
+
+
+J N
+
+W Z
+
+
+
+# ,
+
+G K
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+$ %
+
+
+
+
+
+
+
+
+
+
+
+
+H L
+
+
+
+
+
+
+
+" &
+
+
+
+
+
+
+
+
+
+
+
+
+$ %
+
+
+
+
+
+
+
+
+
+
+
+
+H L
+
+
+
+
+
+
+
+" &
+
+
+
+
+
+
+
+
+
+
+
+
+$ %
+
+
+
+
+
+
+
+
+
+
+
+
+? C
+
+# &
+
+
+
+2 6
+
+
+
+0 4
+
+
+
+' +
+
+
+
+
+
+
+
+
+
+
+
+
+# $
+
+
+
+
+
+
+
+
+
+
+\ `
+
+
+
+( ,
+
+
+
+
+
+* .
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+4 7
+
+3 4
+
+5 6
+
+
+
+
+
+
+
+
+
+
+
+
+I M
+
+
+
+# ,
+
+D H
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+( )
+
+
+
+ 3
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+g k
+
+
+
+% .
+
+F c
+
+* /
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+* +
+
+
+
+ 8
+
+
+
+
+
+
+
+
+
+
+B F
+
+
+
+! %
+
+
+
+
+
+
+
+
+
+
+
+
+
+
++ ,
+
+
+
+
+
+
+
++ H
+
+
+
+
+
+
+
+
+
+
+
+
+
+( ,
+
+
+
+
+
+, -
+
+
\ No newline at end of file
diff --git a/src/src/build/sonar/scanner-report/syntax-highlightings-24.pb b/src/src/build/sonar/scanner-report/syntax-highlightings-24.pb
new file mode 100644
index 0000000..22a324c
--- /dev/null
+++ b/src/src/build/sonar/scanner-report/syntax-highlightings-24.pb
@@ -0,0 +1,238 @@
+
+
+
+
+
+
+
+
+
+
+
+
+6 A
+
+
+
+
+8 E
+
+
+
+
+8 E
+
+
+
+
+? G
+
+
+
+
+? H
+
+
+
+
+= C
+!!
+
+!!
+!!
+!!? G
+##
+
+##
+##
+##7 C
+%%
+
+%%
+%%
+%%9 G
+''
+
+''
+''
+''; K
+))
+
+))
+))
+))6 A
+++
+
+++
+++
+++< M
+--
+
+--
+--
+--< M
+//
+
+//
+//
+//4 =
+11
+
+11
+11
+116 A
+33
+
+33
+33
+338 E
+55
+
+55
+55
+55= O
+77
+
+77
+77
+779 G
+99
+
+99
+99
+998 E
+;;
+
+;;
+;;
+;;8 E
+==
+
+==
+==
+==/ 3
+??
+
+??
+??
+??2 9
+AA
+
+AA
+AA
+AA: I
+CC
+
+CC
+CC
+CC> Q
+EE
+
+EE
+EE
+EE4 =
+GG
+
+GG
+GG
+GG2 9
+II
+
+II
+II
+II1 7
+KK
+
+KK
+KK
+KK3 ;
+MM
+
+MM
+MM
+MM2 9
+OO
+
+OO
+OO
+OO6 A
+QQ
+
+QQ
+QQ
+QQ= O
+SS
+
+SS
+SS
+SS4 =
+UU
+
+UU
+UU
+UU8 E
+WW
+
+WW
+WW
+WW2 9
+YY
+
+YY
+YY
+YY1 7
+[[
+
+[[
+[[
+[[7 >
+]]
+
+]]
+]]
+]]6 <
+__
+
+__
+__
+__1 7
+aa
+
+aa
+aa
+aa5 C
+cc
+
+cc
+cc
+cc0 9
+ee
+
+ee
+ee
+ee2 =
+gg
+
+gg
+gg
+gg- 7
+ii
+
+ii
+ii
+ii4 >
+kk
+
+kk
+kk
+kk0 ;
+mm
+
+mm
+mm
+mm0 ;
+oo
+
+oo
+oo
+oo0 U
\ No newline at end of file
diff --git a/src/src/build/sonar/scanner-report/syntax-highlightings-25.pb b/src/src/build/sonar/scanner-report/syntax-highlightings-25.pb
new file mode 100644
index 0000000..cf5f290
--- /dev/null
+++ b/src/src/build/sonar/scanner-report/syntax-highlightings-25.pb
@@ -0,0 +1,572 @@
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+5 9
+\ _
+f m
+( ,
+
+
+
+) ,
+ 3
+& +
+
+!!
+""
+## "
+&&
+''
+))
+
+,,
+02
+33
+33
+334 8
+44
+55
+
+55
+77
+
+77
+77
+889 :
+99
+
+99
+99
+;;& *
+<<
+>>A E
+@@
+DD
+HM
+NN
+
+NN
+PP- 0
+PP2 5
+RR% (
+SS
+TT4 6
+UU
+XX
+ZZ
+^e
+ff
+
+ff
+ff
+gg, /
+gg: =
+hh (
+ii
+ii
+jj
+jj
+kk
+kk
+mm
+
+oo K
+pp
+qq
+qq
+qq0 5
+qqA F
+rr
+rr
+rr/ 4
+rr? D
+tt I
+uu
+vv M
+ww *
+{{
+ ~
+
+
+
+
+
+
+9 <
+
+G J
+
+
+
+. 1
+
+% )
+
+ !
+
+ .
+
+% *
+
+1 4
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+! $
+
+
+
+
+
+
+
+
+
+
+7 :
+
+E H
+ A
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ !
+
+
+
+ "
+
+
+
+> ?
+
+A B
+
+# '
+
+ =
+
+ ?
+
+5 8
+
+: @
+
+
+
+ /
+
+
+
+
+
+
+3 6
+
+> A
+
+( +
+
+% )
+
+* 9
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+* +
+
+8 9
+
+G H
+
+
+
+= >
+
+
+
+ (
+
+% *
+
+
+
+
+
+
+
+
+
+
+> C
+
+L Q
+
+( +
+
+ 6
+
+% )
+
+B L
+
+% *
+
+
+
+
+
+ )
+
+
+
+ '
+
+
+
+ '
+
+ *
+
+
+
+
+
+
+
+
+
+
+ 1
+
+
+
+
+
+
+
+
+% 8
+
+
+
+
+
+
+
+
+
+
+" *
+
+ ;
+
+ N
+
+
+
+
+
+
+
+
+
+
+; @
+
+I N
+
+# &
+
+3 6
+
+
+
+
+& *
+
++ /
+
+2 i
+
+ &
+
+7 9
+
+? X
+
+" %
+
+( +
+
+ 6
+
+% )
+
+7 ;
+
+% *
+
+
+
+
+
+
+
+ 3
+
+
+
+ 2
+
+ *
+
+
+
+
+
+
+
+
+
+
+ 1
+
+
+
+
+
+
+
+
+% 8
+
+
+
+
+
+
+
+
+
+
+" *
+
+ ;
+
+
+
+0 4
+
+
+
+
+
+
+
+
+
+H L
+
+
+ D
+
+
+
+
+
+
+
+
+
+
+5 8
+
+# &
+
+
+
+
+
+
+
+ ;
+
+
+
+
+
+* .
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+6 7
+
+
+
+
+
+
+
+
+
+
+3 9
+
+D J
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ "
+
+
+
+ #
+
+
+
+5 6
+
+8 9
+
+< ?
+
+
+
+& *
+
+' *
+
+, 2
+
+
\ No newline at end of file
diff --git a/src/src/build/sonar/scanner-report/syntax-highlightings-26.pb b/src/src/build/sonar/scanner-report/syntax-highlightings-26.pb
new file mode 100644
index 0000000..41d8292
--- /dev/null
+++ b/src/src/build/sonar/scanner-report/syntax-highlightings-26.pb
@@ -0,0 +1,289 @@
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+/ 0
+
+
+
+
+
+ / 0
+!!
+
+!!
+!!
+!!
+!!/ 0
+""
+
+""
+""
+""
+""/ 0
+##
+
+##
+##
+##
+##/ 0
+%%
+
+%%
+%%
+%%
+''
+
+''
+''
+''
+''/ 0
+((
+
+((
+((
+((
+((/ 0
+))
+
+))
+))
+))
+))/ 0
+**
+
+**
+**
+**
+**/ 0
+,,
+
+,,
+,,
+,,
+..
+
+..
+..
+//
+//
+//
+//
+//8 ;
+//< ?
+77
+77
+77
+77
+77> A
+77B E
+??
+??
+??
+??, /
+@@
+CC
+CC
+CC
+CC1 4
+DD
+HH
+
+HH
+HH
+II
+
+JJE J
+KK
+LL& )
+MM
+MM
+NN
+OO &
+PP &
+PP( :
+QQ
+TT
+
+UU
+YY
+
+YY
+YY
+ZZ
+ZZ
+ZZ
+ZZ
+ZZ9 <
+ZZ= @
+bb
+bb
+bb
+bb
+bb: =
+bb> A
+jj
+jj
+jj
+jj
+jj8 ;
+jj< ?
+rr
+rr
+rr
+rr
+rr: =
+rr> A
+zz
+zz
+zz
+zz, /
+{{
+~~
+~~
+~~
+~~+ .
+
+
+
+
+
+
+
+
+- 0
+
+
+
+
+
+
+
+
+
+- 0
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+6 9
+
+: =
+
+
+
+
+
+
+
+0 3
+
+
+
+
+
+
+
+
+
+
+
+6 9
+
+: =
+
+
+
+
+
+
+
+0 3
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+? B
+
+C F
+
+
+
+
+
+
+
+3 6
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
\ No newline at end of file
diff --git a/src/src/build/sonar/scanner-report/syntax-highlightings-27.pb b/src/src/build/sonar/scanner-report/syntax-highlightings-27.pb
new file mode 100644
index 0000000..9f906f0
--- /dev/null
+++ b/src/src/build/sonar/scanner-report/syntax-highlightings-27.pb
@@ -0,0 +1,77 @@
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+$ '
+
+!
+""
+
+""
+""
+%%$ '
+''
+*.
+//
+
+//
+//
+00
+00
+11
+22+ I
+44
+449 L
+77
+
+::
+=?
+@@
+
+@@
+BB$ (
+EE
+FF
+GG
+HH& '
+HH) *
+JJ
+MP
+QQ
+
+QQ
+SS$ (
+VV
+XX
+YY
+ZZ
+[[
+\\& '
+__
\ No newline at end of file
diff --git a/src/src/build/sonar/scanner-report/syntax-highlightings-28.pb b/src/src/build/sonar/scanner-report/syntax-highlightings-28.pb
new file mode 100644
index 0000000..55f9cb3
--- /dev/null
+++ b/src/src/build/sonar/scanner-report/syntax-highlightings-28.pb
@@ -0,0 +1,182 @@
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+!!
+
+""
+
+##
+
+%%
+
+&&
+
+''
+
+))
+
+++
+++
+
+..
+..
+.. '
+..1 ;
+//
+//
+00
+11
+11
+11
+11
+114 6
+44
+55
+55
+558 E
+66
+99
+::G O
+<<
+
+CC$ H
+EE
+FFJ K
+GG0 4
+HHU V
+KK
+
+LL "
+MM #
+NN
+QQ
+RR
+SS
+
+VV
+
+[[
+[[
+[[" 0
+]]
+``
+``
+aa> B
+cc
+dd> ?
+ff
+
+ff" #
+ffF G
+hh
+
+kk
+ll" &
+nn #
+pp
+
+qq .
+rr "
+ss )
+tt
+
+uu .
+vv "
+ww )
+xx
+
+yy .
+zz "
+{{ )
+||
+
+}} .
+~~ "
+ )
+
+
+
+
+
+% (
+
+= A
+
+8 <
+
+
+
+
+? C
+
++ /
+
+
+
+
+
+
+0 3
+
+
+
+
+
+ #
+
++ /
+
+B G
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
\ No newline at end of file
diff --git a/src/src/build/sonar/scanner-report/syntax-highlightings-29.pb b/src/src/build/sonar/scanner-report/syntax-highlightings-29.pb
new file mode 100644
index 0000000..c80b161
--- /dev/null
+++ b/src/src/build/sonar/scanner-report/syntax-highlightings-29.pb
@@ -0,0 +1,61 @@
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ &
+!!
+!!
+!!
+!!0 3
+&&
+&&
+&&
+&&
+&&8 9
+''
+''
+''
+''
+''8 9
+))
+**
+
+**
+++
+..+ 4
+..J M
+//
+00
+22
+
+22
+33
+44
+55
+66$ '
+66F K
+88V W
+88a b
+<<
\ No newline at end of file
diff --git a/src/src/build/sonar/scanner-report/syntax-highlightings-3.pb b/src/src/build/sonar/scanner-report/syntax-highlightings-3.pb
new file mode 100644
index 0000000..f12b23e
--- /dev/null
+++ b/src/src/build/sonar/scanner-report/syntax-highlightings-3.pb
@@ -0,0 +1,366 @@
+
+
+
+
+
+
+ $
+$ &
+
+
+
+
+
+ D
+
+
+
+
+
+
+
+
+ !
+" M
+M P
+P `
+
+ !
+" T
+T W
+W n
+
+ !
+" ?
+? B
+B Q
+
+ !
+" D
+D G
+G Y
+
+ !
+" F
+F I
+I z
+
+ !
+" L
+L O
+ O
+
+ !
+" C
+C F
+F Y
+
+ !
+" F
+F I
+I m
+
+ !
+ " M
+ M P
+ P l
+!!
+!! !
+!!" C
+!!C E
+""
+##
+## )
+$$
+$$ (
+$$( *
+%%
+&&
+&& 0
+'' !
+''" I
+((
+(( ,
+))
+)) *
+**
+** ,
+++ '
+++( 3
+++3 5
+,, ?
+--
+--
+..
+.. $
+..% A
+..A D
+//
+// &
+//' I
+//I L
+00
+22
+44
+55
+55 /
+66 !
+66" I
+77
+77 *
+88
+88 ,
+88, .
+::
+::
+;;
+;; $
+;;% A
+;;A D
+<<
+<< &
+<<' H
+<<H K
+==
+== &
+==' J
+==J M
+>>
+>> &
+>>' J
+>>J M
+??
+AA
+AA
+BB
+BB $
+BB% K
+BBK N
+CC
+CC &
+CC' H
+CCH K
+DD
+DD &
+DD' J
+DDJ M
+EE
+EE &
+EE' J
+EEJ M
+FF
+HH
+HH
+II
+II $
+II% C
+IIC F
+JJ
+JJ &
+JJ' H
+JJH K
+KK
+MM
+NN
+NN 5
+OO
+OO! 2
+OO2 5
+PP
+RR
+SS
+SS >
+TT
+TT .
+UU
+UU! '
+UU' *
+WW
+XX
+XX 8
+YY
+YY 1
+YY1 3
+ZZ
+ZZ
+[[
+[[ $
+[[% P
+[[P S
+\\
+\\ $
+\\% Q
+\\Q T
+]]
+]] $
+]]% Q
+]]Q T
+^^
+``
+aa
+aa 9
+bb
+bb! 6
+bb6 9
+cc
+dd
+ee
+ee 8
+ff
+ff 1
+ff1 3
+hh
+hh
+ii
+ii $
+ii% P
+iiP S
+jj
+jj $
+jj% Q
+jjQ T
+kk
+kk $
+kk% Q
+kkQ T
+ll
+nn
+oo
+oo 9
+pp
+pp! 6
+pp6 9
+qq
+ss
+ss
+ss 6
+ss6 8
+tt
+tt
+uu
+uu $
+uu% K
+uuK N
+vv
+ww
+yy
+zz
+zz <
+{{
+{{ %
+{{% '
+||
+~~
+
+ 1
+
+
+
+ ,
+
+
+
+ /
+
+
+
+ J
+
+J L
+
+
+
+
+
+
+
+ &
+
+
+
+ #
+
+
+
+ /
+
+
+
+ J
+
+J L
+
+
+
+
+
+
+
+ -
+
+
+
+ *
+
+
+
+ /
+
+
+
+ J
+
+J L
+
+
+
+
+
+
+
+ F
+
+
+
+ 5
+
+
+
+ *
+
+
+
+ ;
+
+; =
+
+
+
+
+
+
+
+ I
+
+
+
+ $
+
+$ &
+
+
+
+
+
+
+
+ 9
+
+
+
+ 0
+
+0 3
+
+
+
\ No newline at end of file
diff --git a/src/src/build/sonar/scanner-report/syntax-highlightings-30.pb b/src/src/build/sonar/scanner-report/syntax-highlightings-30.pb
new file mode 100644
index 0000000..ff72957
--- /dev/null
+++ b/src/src/build/sonar/scanner-report/syntax-highlightings-30.pb
@@ -0,0 +1,20 @@
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ "
+
+
+
+
+4 9
\ No newline at end of file
diff --git a/src/src/build/sonar/scanner-report/syntax-highlightings-31.pb b/src/src/build/sonar/scanner-report/syntax-highlightings-31.pb
new file mode 100644
index 0000000..71a8c02
--- /dev/null
+++ b/src/src/build/sonar/scanner-report/syntax-highlightings-31.pb
@@ -0,0 +1,564 @@
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ #
+!!
+!!
+!!
+!!
+!!8 <
+##
+##
+##
+##
+##1 3
+$$
+$$
+$$
+$$
+$$0 2
+%%
+%%
+%%
+%%
+%%0 1
+&&
+&&
+&&
+&&
+&&4 5
+''
+''
+''
+''
+''G H
+((
+((
+((
+((
+((A B
+))
+))
+))
+))
+))A C
+**
+**
+**
+**
+**A B
+++
+++
+++
+++
+++A C
+,,
+,,
+,,
+,,
+,,5 6
+--
+--
+--
+--
+--5 7
+..
+..
+..
+..
+..4 5
+//
+//
+//
+//
+//4 5
+11
+11
+22
+22
+33
+33
+44
+44
+55
+77
+77* -
+99
+99
+;;
+;;
+==
+==
+??
+??
+AA
+CC
+CCH K
+DD
+EE
+EE
+EE7 :
+EEC F
+LL
+LLH K
+MM
+NN
+NN
+NN7 :
+NNC F
+OO
+OO$ )
+QQ
+RR
+RR< =
+TT2 3
+UU$ (
+VV
+VV
+VVa b
+XX3 4
+YY$ (
+[[
+[[2 3
+\\U V
+``
+aa
+aa1 2
+aa@ A
+cc2 3
+dd$ (
+ee
+ee
+ee% &
+eeG H
+gg3 4
+hh$ (
+kk
+kkQ R
+nn
+vv
+vvJ M
+ww
+xx
+xx
+xx7 :
+xxC F
+yy
+zz
+{{
+{{
+||
+}}
+~~
+~~
+
+
+
+
+
+
+
+
+
+
+ !
+
+
+
+
+
+
+
+H K
+
+
+
+
+
+
+
+7 :
+
+C F
+
+
+
+
+
+
+
+
+
+
+
+
+4 7
+
+> A
+
+
+
+ #
+
+/ 2
+
+
+
+
+
+
+
+
+
++ /
+
+
+
+
+
+
++ /
+
+6 =
+
+
+
+
+
+3 7
+
+4 7
+
+" %
+
+ +
+
+
+
+ '
+
+
+
+
+
+
+
+
+
+
+ "
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ #
+
+
+
+
+
+
+
+
+ "
+
+) ,
+
+
+
+
+
++ .
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ "
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ #
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ !
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ "
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+! "
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+! $
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ %
+
+
+
+
+
+
+
+
+
+
+
+
+: ;
+
+> ?
+
+( ,
+
+
+
+
+
+
+
+* +
+
+? K
+
+1 2
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+* .
+
+9 =
\ No newline at end of file
diff --git a/src/src/build/sonar/scanner-report/syntax-highlightings-32.pb b/src/src/build/sonar/scanner-report/syntax-highlightings-32.pb
new file mode 100644
index 0000000..eec4a51
--- /dev/null
+++ b/src/src/build/sonar/scanner-report/syntax-highlightings-32.pb
@@ -0,0 +1,77 @@
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ " )
+ 6 @
+""
+##
+##
+$$
+%%
+''
+
+''
+((
+((/ 3
+++
+
+++1 5
+,,
+--
+//5 8
+00
+00
+00? B
+00I L
+11
+11$ '
+113 6
+;;# $
+==B F
+>>X \
+??0 4
+CC
+
+CC
+CC %
+GG
+
+GG
+KK
+KK
+KK !
+LL
+QQ* .
+TT
+
+TT
+TT. 1
+UU
+
+UU& *
+VV1 5
\ No newline at end of file
diff --git a/src/src/build/sonar/scanner-report/syntax-highlightings-33.pb b/src/src/build/sonar/scanner-report/syntax-highlightings-33.pb
new file mode 100644
index 0000000..40265b5
--- /dev/null
+++ b/src/src/build/sonar/scanner-report/syntax-highlightings-33.pb
@@ -0,0 +1,49 @@
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+!!
+##
+
+##8 ;
+&&
+))# &
+**
+**
+00
+
+00
+11
+
+11
+66
+
+66
+77
+::
+
+::
\ No newline at end of file
diff --git a/src/src/build/sonar/scanner-report/syntax-highlightings-34.pb b/src/src/build/sonar/scanner-report/syntax-highlightings-34.pb
new file mode 100644
index 0000000..544d6e3
--- /dev/null
+++ b/src/src/build/sonar/scanner-report/syntax-highlightings-34.pb
@@ -0,0 +1,74 @@
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ '
+!!
+
+!!
+!!
+&&
+
+&&
+&&
+&&
+&&* +
+''
+
+''
+''
+''
+''* +
+))
+
+**
+++ /
+..
+//
+
+00
+00
+33
+44
+
+44
+55
+
+55
+<<
+
+<<1 4
+>>
+BB
+BB
+BB! (
+CC
+EE
+FF
+GG8 <
+KK
+KK
\ No newline at end of file
diff --git a/src/src/build/sonar/scanner-report/syntax-highlightings-35.pb b/src/src/build/sonar/scanner-report/syntax-highlightings-35.pb
new file mode 100644
index 0000000..e5ed267
--- /dev/null
+++ b/src/src/build/sonar/scanner-report/syntax-highlightings-35.pb
@@ -0,0 +1,121 @@
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ #
+
+
+
+
+
+
+ $
+!!
+""
+##
+$$
+%%
+%%
+&&
+''
+))
+**& /
+++ "
+--9 =
+--? B
+--y z
+ --|
+..
+11& '
+22. 1
+33
+44
+44
+44R W
+55N R
+55S X
+66
+88 /
+::
+;;4 7
+<<
+==
+==
+==C F
+>> %
+@@@ N
+CC
+EE1 4
+EE5 8
+EE9 ;
+EE< F
+GG
+GG7 ;
+HH+ /
+HH0 3
+JJ %
+KK "
+KK# '
+KKQ T
+LL >
+MMN W
+NN "
+NNN U
+NN^ e
+OOR X
+QQ$ 0
+RRZ r
+SS$ *
+UU$ *
+XX $
+XX% <
+YYR X
+[[B F
+[[G W
+\\Z r
+]]$ ,
+__$ ,
+dd- 1
+dd3 7
\ No newline at end of file
diff --git a/src/src/build/sonar/scanner-report/syntax-highlightings-36.pb b/src/src/build/sonar/scanner-report/syntax-highlightings-36.pb
new file mode 100644
index 0000000..a7e8741
--- /dev/null
+++ b/src/src/build/sonar/scanner-report/syntax-highlightings-36.pb
@@ -0,0 +1,154 @@
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ ~
+
+
+
+ (
+
+
+
+ !
+ " $
+ % '
+ ( *
+ , 2
+!!
+!!
+!!
+!! )
+##
+$$
+$$
+%%
+))
+++ #
+--
+..
+00 !
+11
+22
+33
+44" %
+55- <
+77
+88% (
+99
+::
+::
+;;
+<<
+==
+>>
+??
+BB
+CC
+DD
+EE
+FF
+GG 5
+II
+MM
+NN
+OO
+PP
+QQ
+RR
+TT %
+UU
+UU
+ZZ
+
+ZZ
+ZZ& 8
+\\
+]]" %
+__
+``
+
+``
+aa/ 0
+dd
+ee
+
+ee
+ff4 5
+ii
+
+jj
+
+jj
+kk
+llE H
+llf l
+mm
+oo
+pp
+qq 9
+rr; >
+ss
+ss! '
+tt
+
+ww
+ww$ 5
+xx $
+xx0 9
+yy% 4
+zz
\ No newline at end of file
diff --git a/src/src/build/sonar/scanner-report/syntax-highlightings-37.pb b/src/src/build/sonar/scanner-report/syntax-highlightings-37.pb
new file mode 100644
index 0000000..c6b0a83
--- /dev/null
+++ b/src/src/build/sonar/scanner-report/syntax-highlightings-37.pb
@@ -0,0 +1,2285 @@
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+!!
+
+""
+
+##
+
+$$
+
+%%
+
+&&
+
+''
+
+((
+
+))
+
+**
+
+++
+
+,,
+
+--
+
+..
+
+//
+
+00
+
+11
+
+22
+
+33
+
+44
+
+55
+
+66
+
+77
+
+88
+
+99
+
+::
+
+;;
+
+<<
+
+==
+
+>>
+
+??
+
+@@
+
+AA
+
+BB
+
+CC
+
+DD
+
+FF
+
+GG
+
+II
+
+JJ
+
+KK
+
+LL
+
+MM
+
+NN
+
+OO
+
+PP
+
+QQ
+
+RR
+
+SS
+
+TT
+
+UU
+
+VV
+
+WW
+
+YY
+
+ZZ
+
+[[
+
+\\
+
+]]
+
+^^
+
+__
+
+``
+
+aa
+
+bb
+
+cc
+
+dd
+
+ee
+
+ff
+
+ii
+ii
+ii %
+ii/ 9
+mm
+mm
+nn
+pp
+rr
+tt
+ww
+ww
+ww
+wwD G
+yy
+
+
+
+
+
+
+
+
+I L
+
+
+
+
+
+
+
+
+
+
+B E
+
+
+
+
+
+
+
+
+
+
+K N
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+& 8
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+7 G
+
+
+
+
+
+
+
+
+
+; =
+
+
+
+
+
+
+
+
+< D
+
+F P
+
+
+
+
+
+
+
+
+> F
+
+H R
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+" &
+
+
+
+
+
+$ '
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+) /
+
+) ,
+
+
+
+
+
+) *
+
+C D
+
+F H
+
+
+
+
+
+
+* +
+
+
+
+
+
+
+) -
+
+
+
+
+
+C D
+
+F H
+
+
+
+
+
+
+
+
+
+
+
+) ,
+
+
+
+
+
+C D
+
+F H
+
+
+
+
+
+
+
+
+
+
+
+
+ &
+
++ .
+
+
+
+ !
+
+
+
+
+
+
+
+: =
+
+E H
+
+P S
+
+! )
+
+
+
+
+
+
+
+6 9
+
+A D
+
+M P
+
+
+
+
+
+
+
+! )
+
+
+
+
+
+
+
+
+
+
+
+ +
+
+
+
+( 3
+
+5 6
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ A
+
+
+
+
+
+
+
+
+
+
+/ Y
+
+
+
+% (
+
+T W
+
+ .
+
+
+
+
+
+
+
+ !
+
+" &
+
+
+
+
+
+
+
+* +
+
+. ^
+
+
+
+' I
+
+
+
+
+
+
+
+
+
+
+
+
+
+ *
+
+
+
+
+
+
+
+
+
+
+
+
+
+ $
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ 9
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+" &
+
+
+
+
+
+
+
+ 7
+
+
+
+
+
+
+
+
+
+
+
+
+8 9
+
+
+
+
+
+
+
+
+
+ !
+
+) -
+
+A F
+
+
+
+
+
+
+
+0 4
+
+
+
+$ (
+
+ >
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+N O
+
+
+
+
+
+
+
+2 6
+
+ %
+
+
+
+N O
+
+
+
+
+
+0 4
+
+
+
+ ?
+
+
+
+
+
+
+
+2 3
+
+4 8
+
+
+
+( ,
+
+# G
+
+
+
+ $
+
+
+
+? C
+
+
+
+; ?
+
+
+
+
+
+
+P ^
+
+M ^
+
++ .
+
+C G
+
+
+
+
+
+
+
+
+ H
+
+
+
+
+
+7 ;
+
+
+
+
+
+
+
+
+
+& *
+
+
+
+
+
+
+
+
+
+F J
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ +
+
+I _
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+! "
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+: >
+
+: @
+
+
+
+
+
+" &
+
+
+
+
+
+$ (
+
+E I
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+8 =
+
+
+
+
+
+
+
+
+8 =
+
+
+
+
+ /
+
+
+
+> A
+
+B E
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+. 2
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+) I
+
+ 8
+
+ >
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+4 <
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+; @
+
+
+
+
+= B
+
+
+
+
+
+
+
+
+
+
+6 ;
+
+
+
+
+> C
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+# ,
+
+
+
+ (
+
+
+
+
+
+& .
+
+
+
+
+
+" *
+
+
+
+
+
+& 3
+
+
+
+< >
+
+< O
+
+
+
+
+
+
+
+( 3
+
+
+
+
+
+
+
+
+
+. 1
+
+F J
+
+
+
+ "
+
+# '
+
+H K
+
+C G
+
+
+
+
+
+
+
+
+
+Q R
+
+3 4
+
+6 :
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+* +
+
+- 2
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+! $
+
+: >
+
+# &
+
+
+
+
+
+: >
+
+0 4
+
+
+
+
+
+
+
+
+
+ #
+
+
+
+
+
+" *
+
+ .
+
+ 3
+
+
+
+# '
+
+: ?
+
+ "
+
+$ &
+
+
+
+
+
+
+
+
+ #
+
+
+
+
+
+
+
+ =
+
+
+
+
+
+ 2
+
+
+
+
+
+ U
+
+! %
+
+
+
+
+
+
+
+: >
+
+R S
+
+
+
+
+
+
+$ (
+
+/ 6
+
+
+
+
+
+
+
+
+
+' (
+
+
+
+' +
+
+; @
+
+E I
+
+K L
+
+V W
+
+
+
+
+
+
+
+
+
+
+ 2
+
+
+
+
+
+
+
+
+
+
+
+! $
+
+: @
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+" #
+
+
+
+
+
+
+
+
+; <
+
+
+
+
+C D
+
+
+
+
+
+
+
+
+ #
+
+
+
+
+
+
+ P
+
+
+
+
+
+
+
+
+
+
+
+
+
+$ (
+
+
+
+
+
+
+
+
+
+* ,
+
+
+
+$ '
+
+D H
+
+K M
+
+
+
+
+
+
+
+
+
+
+
+
+0 4
+
+
+
+
+
+* -
+
+( ,
+
+T X
+
+
+
+ #
+
+& )
+
+
+
+
+
+D K
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+) -
+
+
+
+
+
+
+
+
+
+
+( /
+
+
+
+
+ 7
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+' *
+
+4 7
+
+B R
+
+
+
+
+
+
+
+
+
+^ a
+
+
+
+ 8
+
+ C
+
+ P
+
+
+
+
+
+
+
+ "
+
+
+
+
+J Z
+
+ "
+
+
+
+
+
+
+
+E S
+
+
+
+
+
+6 9
+
+Y ]
+
+% )
+
+
+
+8 ;
+
+[ _
+
+
+
+
+
+
+
+
+
+
+ 0
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+' (
+
+
+
+$ '
+
+/ 3
+
+F K
+
+< @
+
+ '
+
+) -
+
+ K
+
+
+
+
+
+
+ .
+
+
+
+/ 1
+
+1 3
+
+
+
+R S
+
+
+
+
+
+
+
+
+
+
+
+
+
+& )
+
+
+
+
+
+
+
+
+
+" ,
+t
+
+
+
+
+" &
+
+O P
+
+R s
+
+
+
+
+
++ 5
+
+J K
+
+M W
+
+
+
+
+
+ !
+
+
+
+, /
+
+D H
+
+J U
+
+( ,
+
+K O
+
+Q b
+
+
+
+R f
+
+
+
+Q e
+
+ "
+
+7 ;
+
+= E
+
+; >
+
+
+
+
+
+8 ;
+
+D L
+
+% /
+
+
+
+; C
+
+
+
+S d
+
+$ '
+
+
+
+
+
+) :
+
+% 6
+
+
+
+M W
+
+ c
+
+
+
+U V
+
+X
+
+9 :
+
+< A
+
+! +
+
+
+
+
+1 P
+
+ %
+
+% (
+
+8 W
+
+
+
+
+
+: =
+
+E H
+
+P S
+
+\ o
+
+ 2
+
+
+
+
+
+6 9
+
+A D
+
+M P
+
+Y i
+
+
+
+9 V
+
+( -
+
+
+
+( ,
+
+
+
+
+
+6 I
+
+ 2
+
+
+
+
+
+I J
+
+- .
+
+0 5
+
+
+
+
+
+; ?
+
+A D
+
+{ |
+~
+
+; ?
+
+A D
+
+z {
+}
+
+
+
+9 G
+
+ "
+
+) *
+
+, ]
+
+
+
+
+
+
+
+$ '
+
+5 8
+
+S h
+
+
+
+
+
+
+
+ )
+
+
+
+ !
+
+ (
+
+R V
+
+X \
+
+^ b
+
+ *
+
+
+
+ =
+
+ ,
+
+
+
+
+
+4 8
+
+: E
+
+
+
+
+
+
+
+
+
+
+
+
+
+ ) 6
+
+ O R
+
+ e k
+
+ - 0
+
+ *
+
+
+
+ 4 8
+
+ : E
+
+
+
+
+
+
+
+
+
+
+
+
+
+ ) 6
+
+ M X
+
+ \ b
+
+ - 0
+
+ $
+
+
+
+ 0 4
+
+ 6 >
+
+
+
+
+
+
+
+
+
+
+
+ &
+
+ 0 6
+
+ 7 L
+
+ 7 E
+
+
+
+
+
+
+
+
+
+
+
+
+ ( ,
+
+
+
+
+ , 0
+
+ 2 T
+
+
+
+
+
+ : U
+
+
+
+ @ D
+
+ ( +
+
+
+
+ !
+
+ 7 9
+
+ = @
+
+ D F
+
+ J M
+
+ !
+
+ , 0
+
+
+
+
+
+
+
+
+
+ < L
+
+
+
+
+
+ . 3
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ 0
+
+ ) -
+
+ , 0
+
+ ! %
+
+
+
+
+
+
+
+
+
+
+ $ g
+
+ ( @
+
+ ( +
+
+
+
+
+
+
+
+ + A
+
+ C E
+
+ N V
+
+
+
+ H L
+
+ N X
+
+
+
+ 4 7
+
+ -
+
+ C E
+
+ I L
+
+ P R
+
+ V Y
+
+ * -
+
+ I M
+
+
+
+
+
+
+
+ # 0
+
+ '
+
+
+
+ $ '
+
+ 5
+
+ 0 3
+
+ 4 7
+
+ 9 ?
+
+
+
+
+
+
+
+
+
+
+ ; ?
+
+ A D
+
+ { |
+ ~
+
+ ; ?
+
+ A D
+
+ z {
+ }
+
+
+
+
+
+ % I
+
+ K a
+
+ ) *
+
+ , ?
+
+
+
+
+
+ / <
+
+
+
+
+
+
+
+
+ E
+
+
+
+
+
+
+
+
+
+
+
+3 9
+
+
+
+; P
+
+
+
+
+
+
+
+ #
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+5 8
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ 2
+
+
+
+
+
+
+
+
+
+
+
+; ?
+
+
+
+A D
+
+
+
+{ |
+
+
+~
+
+
+
+; ?
+
+
+
+A D
+
+
+
+z {
+
+
+}
+
+
+
+
+
+
+
+
+
+
+
+% )
+
+
+
+2 7
+
+
+
+9 I
+
+
+
+) *
+
+
+
+, ?
\ No newline at end of file
diff --git a/src/src/build/sonar/scanner-report/syntax-highlightings-38.pb b/src/src/build/sonar/scanner-report/syntax-highlightings-38.pb
new file mode 100644
index 0000000..64c6d5b
--- /dev/null
+++ b/src/src/build/sonar/scanner-report/syntax-highlightings-38.pb
@@ -0,0 +1,323 @@
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+!!
+
+##
+
+%%
+
+&&
+
+((
+((
+(( !
+))
+))
+))
+))& 4
+**
+**
+++
+++
+--
+--
+--
+--- 3
+..
+..
+..
+... 5
+//
+//
+//
+/// 8
+11
+11
+11
+11D G
+22
+
+8:
+;;
+
+;;
+<?
+@@
+@@ !
+BE
+FF
+FF
+HJ
+KK
+KK
+KK% ,
+NN
+PP
+
+QQ
+QQ
+RR
+UU
+
+UU
+UU
+YY
+
+YY
+]]
+
+^^
+aa
+
+aa= @
+bb
+cc /
+ff
+gg
+
+gg
+hh
+ii
+kk
+kk
+ll
+ll
+ss
+tt
+vv
+ww
+xx
+{{
+{{
+~~
+
+
+
+
+
+
+
+
+
+( /
+
+
+
+1 5
+
+
+
+
+
+
+
+
+
+& 3
+
+
+
+
+
+
+
+
+
+
+
+/ F
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+1 5
+
+
+
+
+
+F G
+
+
+
+ #
+
+
+
+ G
+
+
+
+
+
+
+
+1 5
+
+
+
+2 3
+
+G H
+
+
+
+ G
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+" )
+
+3 6
+
+_ x
+
+
+
+
+) -
+
+
+
+? D
+
+
+
+? C
+
+
+
+
+
+
+
+
+
+: V
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+T Y
+
+[ k
+
+
+
+
+
+
+
+# $
+
+
+
+B G
+
+
+
+
+
+; <
+
+
+
+
+
+$ %
+
+< D
+
+
+
+
+
+
+
+
+
+ "
+
+# *
+
+ 4
+
+% &
+
+= A
+
+ &
+
+' +
+
+
\ No newline at end of file
diff --git a/src/src/build/sonar/scanner-report/syntax-highlightings-39.pb b/src/src/build/sonar/scanner-report/syntax-highlightings-39.pb
new file mode 100644
index 0000000..a25b33c
--- /dev/null
+++ b/src/src/build/sonar/scanner-report/syntax-highlightings-39.pb
@@ -0,0 +1,360 @@
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+( +
+,, #
+00
+00
+00
+00
+00< =
+11
+11
+11
+11
+11< =
+22
+22
+22
+22
+22< =
+33
+33
+33
+33
+33< =
+44
+44
+44
+44
+44< =
+55
+55
+55
+55
+55< =
+66
+66
+66
+66
+66< =
+77
+77
+77
+77
+77< =
+88
+88
+88
+88
+88< =
+99
+99
+99
+99
+99< =
+::
+::
+::
+::
+::< >
+;;
+;;
+;;
+;;
+;;< >
+<<
+<<
+<<
+<<
+<<< >
+==
+==
+==
+==
+==< >
+??
+??
+@@
+@@
+@@ "
+AA
+AA
+AA #
+BB
+BB
+CC
+CC
+DD
+DD
+EE
+EE
+FF
+FF
+GG
+HH
+HH
+II
+II
+JJ
+JJ
+KK
+LL
+MM
+NN
+PP
+PP
+QQ
+QQ
+RR
+RR
+SS
+SS
+TT
+TT
+VV
+
+[[A B
+[[F J
+[[M R
+``B D
+aa0 2
+ee/ 7
+hh
+ii
+
+kk
+mm
+mm !
+ss
+
+ss
+tt
+zz
+zz
+{{( ,
+{{/ 4
+||* .
+||1 6
+}}/ 0
+~~' ,
+$ )
+
+
+
+
+
+
+
+
+
+
+
+
+8 9
+
+7 ;
+
+
+
+4 8
+
+
+
+
+
+
+
+4 a
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
\ No newline at end of file
diff --git a/src/src/build/sonar/scanner-report/syntax-highlightings-4.pb b/src/src/build/sonar/scanner-report/syntax-highlightings-4.pb
new file mode 100644
index 0000000..1ff13be
--- /dev/null
+++ b/src/src/build/sonar/scanner-report/syntax-highlightings-4.pb
@@ -0,0 +1,70 @@
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+& /
+
+
+
+ 6 L
+!!
+!!# '
+!!D G
+""
+""& ,
+## '
+$$ "
+%% '
+''
+
+''
+((
+
+((
+))
+,,
+
+--
+007 :
+44
+66
+77
+99
+
+99
+::
+;;/ 0
+==
+>>
+?? 6
+@@
+@@
+AA
+DD
+
+EE 8
+FF
+FF
\ No newline at end of file
diff --git a/src/src/build/sonar/scanner-report/syntax-highlightings-40.pb b/src/src/build/sonar/scanner-report/syntax-highlightings-40.pb
new file mode 100644
index 0000000..80c650e
--- /dev/null
+++ b/src/src/build/sonar/scanner-report/syntax-highlightings-40.pb
@@ -0,0 +1,2721 @@
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+!!
+
+""
+
+##
+
+$$
+
+%%
+
+&&
+
+''
+
+((
+
+))
+
+**
+
+++
+
+,,
+
+--
+
+..
+
+//
+
+00
+
+11
+
+22
+
+33
+
+44
+
+55
+
+66
+
+77
+
+88
+
+99
+
+::
+
+;;
+
+<<
+
+==
+
+>>
+
+??
+
+@@
+
+AA
+
+BB
+
+CC
+
+DD
+
+EE
+
+FF
+
+GG
+
+HH
+
+JJ
+
+LL
+
+MM
+
+NN
+
+OO
+
+PP
+
+QQ
+
+RR
+
+SS
+
+TT
+
+UU
+
+VV
+
+WW
+
+XX
+
+ZZ
+
+[[
+
+\\
+
+]]
+
+^^
+
+__
+
+aa
+aa
+aa &
+aa0 :
+aae v
+bb
+cc
+cc
+cc
+cc
+cc< =
+dd 0
+ee
+ee
+ee
+ee
+ee7 8
+ff
+gg
+gg
+gg
+gg
+gg2 3
+ii
+ii
+ii
+ii
+ii0 1
+kk
+kk
+kk
+kk
+kk7 8
+ll
+mm
+mm
+mm
+mm> ]
+oo
+pp
+pp
+ss
+ss+ .
+ssD H
+uu
+vv )
+ww
+xx
+yy
+zz
+{{
+||
+}}
+~~
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+& 9
+
+
+
+
+
+
+
+
+
+
+
+
+9 ;
+
+
+
+
+
+
+
+
+
+
+
+
+
+K O
+
+
+
+
+
+
+
+8 ;
+
+Q U
+
+" )
+
+D I
+
+L S
+
+ "
+
+C J
+
+( -
+
+
+
+
+
+
+
+
+
+6 9
+
+: F
+
+
+
+
+
+
+
+
+
+5 8
+
+9 C
+
+
+
+
+
+
+
+
+
+
+
+/ 2
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+8 c
+
+
+
++ >
+
++ 1
+
+
+
+
+
+ 0
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+< @
+
+B E
+
+{ |
+~
+
+
+
+
+
+
+
+
+ (
+
+I M
+
+
+
+! (
+
+1 5
+
+7 @
+
+
+
+1 5
+
+7 @
+
+
+
+
+
+0 H
+
+
+
+! (
+
+1 5
+
+7 @
+
+
+
+1 5
+
+7 @
+
+
+
+
+
+
+
+
+
+ @
+
+
+
+ #
+
+# +
+
+
+
+
+
+
+
+
+$ '
+
+5 8
+
+S k
+
+
+
+
++ /
+
+1 F
+
+ A
+
+
+
+
+
+
+
+
+
+
+
+B K
+
+
+ '
+ '
+
+
+
+
+
+
+
+ /
+
+M Q
+
+
+
+
+8 =
+
+ I
+
+ "
+
+3 O
+
+ !
+
+
+
+H f
+
+
+
+- 0
+
+\ _
+
+ +
+
+
+
+
+
+! $
+
+% )
+
+* .
+
+
+
+
+
+
+
+2 3
+
+6 Y
+
+' (
+
+/ H
+
+
+
+% 0
+
+ >
+
+ 3
+
+
+
+
+
+
+
+
+
+
+
+
+
+# ;
+
+; ?
+
+( G
+
+/ 7
+
+
+
+" [
+
+B F
+
+
+
+ 9
+
+
+
+
+
+ /
+
+1 @
+
+
+
+
+
+
+
+5 =
+
+" %
+
+= A
+
+X [
+
+0 ?
+
+B g
+
+9 =
+
+b f
+
+
+
+
+
+ &
+
+. 1
+
+M X
+
+2 6
+
+8 A
+
+* -
+
+A G
+
+
+
+
+
+
+
+
+
+< C
+
+
+
+
+
+1 5
+
+7 B
+
+? N
+
+' +
+
+- =
+
+' *
+
+E m
+
+
+
+ +
+
+
+
+
+
+? H
+
+) 3
+
+
+
++ ;
+
+
+
+
+
+/ 2
+
+7 :
+
+
+
+
+
+
+
+) 3
+
+
+
+
+
+
+
+ ,
+
+ *
+
+ !
+
+2 3
+
+ *
+
+
+
+! $
+
+
+
+
+
++ >
+
+3 7
+
+
+
+
+
+/ C
+
+" #
+
+
+
+
+
+/ B
+
+" #
+
+
+
+
+
+/ D
+
+" #
+
+
+
+
+
+/ C
+
+" #
+
+
+
+1 5
+
+6 E
+
+6 H
+
+
+
+
+
+" ,
+
+O U
+
+
+
+
+
+ .
+
+
+
+
+
+
+
+
+
+ .
+
+
+
+
+
+ .
+
+
+
+
+
+
+
+
+
+ %
+
+1 6
+
+ .
+
+
+
+
+
+
+
+
+
+ .
+
+
+
+
+
+? D
+
+ $
+
+
+
+ #
+
+R V
+
+X Y
+
+Z d
+
+
+
+" '
+
+V Z
+
+\ ]
+
+^ h
+
+
+
+ #
+
+Q U
+
+W X
+
+Z d
+
+
+
+" '
+
+U Y
+
+[ \
+
+^ h
+
+
+
+
+
+
+
+
+
+
+
+$ %
+
+
+
+X ^
+
+$ %
+
+
+
+
+
+Y ^
+
+$ %
+
+
+
+
+
+U Y
+
+$ %
+
+
+
+$ %
+
+
+
+
+
+) *
+
+1 5
+
+6 >
+
+
+
+
+
+
+
+
+
+ )
+e
+
+
+
++ 2
+
+
+
+' 7
+
+
+
+# -
+
+
+
+
+
+F N
+
+ 1
+
+B F
+
+H d
+
+
+
+I J
+
+% *
+
+, A
+
+
+
+% )
+
++ G
+
+5 9
+
+, 0
+
+2 H
+
+, 1
+
+3 ?
+
+1 @
+
+D H
+
+6 :
+
+< >
+
+
+
+? C
+
+/ 1
+
+= @
+
+
+
+
+
+? E
+
+T [
+
+! )
+
+
+
+
+
+
+
+
+
+
+
+
+
+# 3
+
+
+
+ #
+
+
+
+
+
+
+
+$ (
+
+
+
+$ )
+
+
+
+
+
+ .
+
+
+
+
+
+
+
+
+
+ .
+
+
+
+
+
+
+
+
+
+, 1
+
+3 S
+
+, 0
+
+
+
+
+
+
+
+
+
+? B
+
+M Q
+
+. 5
+
+
+
+
+
+
+
+8 9
+
+1 5
+
+
+
+
+
+
+
+' .
+
+
+
+
+
+2 5
+
+\ `
+
+
+
+ &
+
+' +
+
+4 7
+
+/ @
+
+G K
+
+
+
+? L
+
+
+
+
+
+3 <
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+& /
+
+
+
+! (
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ #
+
+> D
+
+F I
+
+
+
+
+
+7 ;
+
+< @
+
+A E
+
+
+
+
+
+> M
+
+
+
+
+
+
+
+
+
+
+
+
+
+ 0
+
+
+
+
+
+
+
+) 3
+
+
+
+
+
+; D
+
+
+
+
+
+
+
+; D
+
+
+
+D ^
+
+
+
+A L
+
+
+
+* -
+
+< T
+
+
+
+
+
+= N
+
+
+
+
+
+9 =
+
+A C
+
+G d
+
+_ `
+`
+
+H U
+
+ )
+
+ V
+
+ \
+
+ E
+
+ H
+
+
+
+$ (
+
+= ?
+
+D R
+
+( +
+
+H N
+
+( ,
+
+ "
+
+L X
+
+
+
+
+
+
+
+' *
+
+D J
+
+
+
+H T
+
+
+
+
+
+
+
+
+
+D J
+
+$ )
+
+
+
+H T
+
+
+
+
+
+
+
+
+
+
+
+- 5
+
+# E
+
+I M
+
+L O
+
+8 O
+
+& .
+
+M T
+
+ B
+
+ M
+
+ 0
+
+
+
+
+
+
+
+/ 6
+
+J P
+
+ C
+
+
+
+H r
+
+ 3
+
+
+
+ f
+
+
+
+
+
+
+
+' *
+
+Q s
+
+
+
+
+
+2 C
+
+; O
+
+
+
+
+
+- F
+
+
+
+" &
+
+> ?
+
+B I
+
+3 >
+
+
+
+# 8
+
+
+
+
+
+
+
+
+
+
+
+4 O
+
+& )
+
+P T
+
+V _
+
+< I
+
+
+
++ .
+
+B F
+
+P Z
+
+$ '
+
+K ^
+
+
+
+
+
+8 ;
+
+= F
+
+ %
+
+* .
+
+H L
+
+1 7
+
+
+
+
+
+
+
+ "
+
+. 6
+
+
+
+# '
+
+: ?
+
+ #
+
+. A
+
+
+
+
+
+
+
+ 6
+
+
+
+
+
+
+
+$ @
+
+ ;
+
+
+
+
+
+# K
+
+
+
+ !
+
+ O
+
+
+
+
+
+# Y
+
+
+
+ +
+
+
+
+
+
+
+
+O d
+
+
+
+ #
+
+
+
+
+
+T e
+
+U a
+
+M U
+
+
+
+
+
+ "
+
+. 5
+
+
+
+
+/ <
+
+ <
+
+
+
+
+
+
+
+
+
+ 4
+
+
+
+
+ P
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+. :
+
+
+
+# '
+
+: ?
+
+
+
+
+
+
+
+0 8
+
+( 4
+
+# 2
+
+
+
+
+: W
+
+6 <
+
+1 A
+
+
+
+
+. 9
+
+
+
+
+@ T
+
+
+
+
+1 E
+
+. 9
+
+
+
+
+
+
+! 0
+
+
+
+
+
+# *
+
+
+
+
+
+
+
+
+
+
+
+
+
+" )
+t
+
+
+
+
+" &
+
+O P
+
+R l
+
+
+
+
+
++ 2
+
+J K
+
+M T
+
+
+
+
+
+0 5
+
+6 =
+
+G f
+
+
+
+, /
+
+D H
+
+J R
+
+( ,
+
+Q U
+
+W c
+
+
+
+Q _
+
+
+
+
+
+
+
+
+
+
+& *
+
+@ M
+
+N d
+
+
+
+ =
+
+
+
+
+
+
+
+
+
+
+ (
+
+ !
+
+J _
+
+7 ;
+
+= C
+
+; >
+
+
+
+
+
+8 ;
+
+D J
+
+& -
+
+
+
+; A
+
+
+
+S _
+
+$ '
+
+
+
+
+
+) 5
+
+& 2
+
+: <
+
+
+
+O h
+
+5 9
+
+b j
+
+( )
+
+< B
+
+
+
+
+
+ %
+
+
+
+3 :
+
+/ 2
+
+C k
+
+> S
+
+H R
+
+? @
+
+B `
+
+" &
+
+( +
+
+ 4
+
+
+
+
+
+6 B
+
++ .
+
+L `
+
+! (
+
+
+
+
+2 G
+
+ %
+
+
+
+& )
+
+9 N
+
+
+
+
+
+: =
+
+E H
+
+P S
+
+\ i
+
+ 2
+
+
+
+
+
+6 9
+
+A D
+
+M P
+
+Y d
+
+
+
+: N
+
+( -
+
+
+
+( ,
+
+
+
+
+
+6 C
+
+ 2
+
+
+
+
+
+
+
+
+! 2
+
+
+
+ !
+
+
+
+ /
+
+8 A
+
+1 9
+
++ 6
+
+3 A
+
+
+
+
+
+$ :
+
+8 C
+
+
+
+
+
+ #
+
+
+
+& 0
+
+
+
+
+
+ !
+
+
+
+
+
+
+
+ !
+
+/ 2
+
+C X
+
+
+
+M e
+
+
+
+
+
+
+8 =
+
+
+
+
+
+
+
+
+8 =
+
+
+
+
+ /
+
+
+
+> A
+
+B E
+
+
+
+ $
+
+% 1
+
+
+
+
+
+S V
+
+
+
+
+
+] i
+
+
+
+& *
+
+
+
+. /
+
+
+
+0 1
+
+
+
+5 6
+
+
+
+
+
+
+
+
+0 :
+
+
+
+
+ "
+
+: >
+
+
+
+
+
+
+
+
+
+
+9 D
+
+
+
+
+" &
+
+ 9
+
+
+
+
+
+
+
+
+
+
+
+
+
+. 1
+
+F J
+
+
+
+ "
+
+# '
+
+H K
+
+C G
+
+
+
+
+
+/ 4
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+4 I
+
+
+
+
+
+
+ &
+
+
+
+
+
+? D
+
+
+
+
+
+$ %
+
+; @
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ %
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+# ,
+
+
+
+$ 4
+
+1 5
+
+6 ?
+
+
+
+
+
+' 1
+
+
+
+1 5
+
+6 >
+
+
+
+
+
++ 3
+
+
+
+
+
+/ 3
+
+
+
+
+
+# +
+
+
+
+
+
+
+
+# )
+
+
+
+3 7
+
+
+
+ "
+
+4 8
+
+
+
+ #
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ (
+
+
+
+5 9
+
+J O
+
+
+
+
+
+
+
+
+
+
+( .
+
+
+
+
+
+! %
+
+& 3
+
+5 :
+
+< D
+
+
+
+
+
+
+
+
+
+
+ (
+
+
+
+ &
+
+( .
+
+0 7
+
+9 ?
+
++ .
+
+C G
+
+ '
+
+% (
+
+
+
+
+
+
+
+A D
+
+ '
+
+ 2
+
+1 5
+
+
+
+
+
+& /
+
+ "
+
+1 3
+
+
+
+P V
+
+
+
+
+
+
+
+% /
+
+
+
+M Q
+
+S [
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+2 5
+
+\ `
+
+7 ;
+
+9 =
+
+C G
+
+
+
+
+
+2 5
+
+\ `
+
+7 ;
+
+9 =
+
+C G
+
+
+
+
+
+2 5
+
+\ `
+
+7 ;
+
+9 =
+
+C G
+
+
+
+
+
+" -
+
+
+
+: >
+
+R S
+T
+
+
+
+
+
+, 8
+
+' +
+
+< @
+
+
+
+A F
+
+, -
+
+/ >
+
+
+
+
+
+* 4
+
+J l
+
+ !
+
+
+
+
+
+B E
+
+P T
+
+Z d
+
+
+
+
+
+0 a
+
+
+
+9 G
+
+
+
+< J
+
+ S j
+
+ @ D
+
+ M b
+
+
+
+
+
+ ! )
+
+
+
+ # +
+
+
+
+ - :
+
+
+
+ !
+
+ + 2
+
+
+
+ ' E
+
+
+
+
+
+
+
+ , 6
+
+
+
+
+
+ ' F
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ 2 ;
+
+
+
+
+ & (
+
+ * Z
+
+
+
+
+
+ 0 3
+
+ H L
+
+ N V
+
+ , 0
+
+ W [
+
+ ] i
+
+
+
+ ^ l
+
+ #
+
+ ; ?
+
+ A G
+
+ ? B
+
+
+
+
+
+ @ C
+
+ L R
+
+ ! (
+
+
+
+ C I
+
+
+
+ Z f
+
+ , /
+
+
+
+
+
+ 1 =
+
+ - 9
+
+ E O
+
+
+
+ ; B
+
+
+
+
+
+ G M
+
+ ) 0
+
+
+
+ 9 N
+
+ ( -
+
+ - 0
+
+ @ U
+
+
+
+
+
+ B E
+
+ M P
+
+ X [
+
+ d q
+
+ :
+
+
+
+
+
+ > A
+
+ I L
+
+ U X
+
+ a l
+
+
+
+ A U
+
+ 0 5
+
+
+
+ 0 4
+
+
+
+
+
+ > K
+
+ :
+
+
+
+
+
+ 1 E
+
+ . 7
+
+ R \
+
+ p u
+
+
+
+ " *
+
+ > A
+
+ [ ^
+
+
+
+
+
+ , 3
+
+
+
+
+
+
+ E H
+
+ S W
+
+
+
+
+
+
+ , ]
+
+ F Q
+
+
+
+ i |
+
+
+
+ E I
+
+ L Y
+
+ < @
+
+ P T
+
+ ] k
+
+
+
+ 6
+
+
+
+
+
+ K W
+
+ b y
+
+
+
+
\ No newline at end of file
diff --git a/src/src/build/sonar/scanner-report/syntax-highlightings-41.pb b/src/src/build/sonar/scanner-report/syntax-highlightings-41.pb
new file mode 100644
index 0000000..3e2e13f
--- /dev/null
+++ b/src/src/build/sonar/scanner-report/syntax-highlightings-41.pb
@@ -0,0 +1,289 @@
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+""
+""
+"" %
+""5 a
+##
+##
+##
+##& 8
+##9 H
+$$
+$$ %
+%%
+%%5 C
+''
+''
+'' ,
+))
+))
+)) "
+**
+++
+
+++
+++ #
+,,
+--
+..
+..
+..
+00
+00
+11 (
+22
+33, /
+66
+77 +
+88
+88
+;;
+==
+
+==
+==
+==, H
+>>
+>>
+??
+??
+BB
+
+BB. G
+CC
+CC
+DD
+DD9 A
+FF
+FF !
+II
+JJ
+
+KK
+KK
+KK* 6
+NN
+OO
+
+OO
+OOE [
+PP
+
+PP
+PP, E
+QQ$ '
+RRG R
+WW
+
+WW
+WW $
+WW% (
+WW3 8
+WW9 @
+WWK R
+XX. >
+YY )
+\\
+
+\\
+]]
+^^
+``
+
+``
+`` %
+``- A
+aa +
+bb !
+ee
+
+ee
+ee !
+ee, 2
+gg
+gg
+gg
+hh
+ii
+iiJ T
+pp
+
+pp/ B
+qq #
+rr
+ss
+ss0 4
+uu
+vv A
+ww
+}}
+
+
+
+
+< M
+
+. 1
+
+
+
+
+
+0 4
+
+
+
+
+
+0 3
+
+( +
+
+
+
+
+
+ /
+
+
+
+
+
+
+
+
+
+
+
+
+# ,
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+$ ,
+
+
+
+
+
+ !
+
+
+
+
+
+
+" '
+
+( +
+
+7 G
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+' D
+
+
+
+
+
+
+
+
+
+
+- O
+
+
+
+
+
+
+
+# 0
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ +
+
+
\ No newline at end of file
diff --git a/src/src/build/sonar/scanner-report/syntax-highlightings-42.pb b/src/src/build/sonar/scanner-report/syntax-highlightings-42.pb
new file mode 100644
index 0000000..ea26c30
--- /dev/null
+++ b/src/src/build/sonar/scanner-report/syntax-highlightings-42.pb
@@ -0,0 +1,138 @@
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ ?
+
+
+
+!!
+!!
+!! "
+""
+"" &
+##
+## %
+$$
+$$ )
+%%
+%% .
+&&
+&&# *
+''
+'' 0
+((
+(( $
+**
+
+**+ 9
+++
+,,- 1
+55
+
+55
+559 @
+55M T
+55_ |
+66
+
+66> ^
+88* 6
+99
+
+>>
+
+>>: W
+??/ ;
+@@/ ;
+AAQ Z
+DD< E
+EE
+
+EE
+EEG i
+IIM e
+JJ
+JJ" 4
+MM
+PP
+PPQ S
+PPX c
+QQ &
+QQ' .
+QQ@ I
+TT
+WW
+
+XX/ ;
+[[
+[[6 B
+^^7 T
+__0 9
+``. 9
+aa
+bbQ m
+cc
+cc& =
+ff
+ii
+iiU W
+jj# *
+jj+ 2
+mm
+rrS `
+tt &
+ww
+ww
+ww3 L
+xx
+xx% 5
+yy
+
+yy0 B
+zz
+zzA X
+||
+||
+||' 2
+~~
+~~
+~~I `
+
+
+
+R X
+
+
+
+
+H T
+
+
+
+
+
\ No newline at end of file
diff --git a/src/src/build/sonar/scanner-report/syntax-highlightings-43.pb b/src/src/build/sonar/scanner-report/syntax-highlightings-43.pb
new file mode 100644
index 0000000..ae8b37c
--- /dev/null
+++ b/src/src/build/sonar/scanner-report/syntax-highlightings-43.pb
@@ -0,0 +1,661 @@
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+!!
+
+""
+
+##
+
+$$
+
+%%
+
+&&
+
+''
+
+((
+
+))
+
+**
+
+++
+
+,,
+
+--
+
+..
+
+//
+
+00
+
+22
+
+33
+
+44
+
+55
+
+66
+
+88
+
+:: 4
+
+;; 9
+
+<< 4
+
+==
+==
+==% ,
+>>
+
+>>
+>>
+>>1 D
+??
+@@
+
+@@
+@@
+@@> U
+AA
+BB
+
+BB
+BB
+BB; P
+CC
+DD
+
+DD
+DD
+DD= X
+EE
+
+FF
+FF
+FF
+FF> U
+GG
+HH
+HH
+HH
+HH9 F
+JJ
+KK
+
+LL
+MM
+NN
+OO
+
+PP
+PP
+QQ
+RR
+SS
+SS
+SS, ;
+TT
+UU 6
+VV /
+WW1 5
+WW7 K
+YY6 O
+ZZ\ e
+[[
+[[( /
+\\ !
+\\1 >
+]]H p
+^^, 5
+``
+aa* .
+aaR V
+aaX j
+bb, 0
+bb2 6
+ee
+ff
+ff
+ff D
+gg
+ii I
+jj
+kk
+
+mm
+mm $
+nn
+oo
+oo$ )
+pp
+qq
+rr$ (
+ss !
+vv
+xx
+~~
+
+
+
+
+
+
+
+ *
+
+
+
+
+
+
+
+
+
+
+
+
+* 9
+
+% 9
+
+! $
+
+0 4
+
+6 ?
+
+
+
+9 =
+
+P Y
+
+1 4
+
+
+
+
+
+E X
+
+
+
+4 =
+
+
+
+< G
+
+ 8
+
+7 C
+
+
+
+ P
+
+ .
+
+> L
+
+
+
+ (
+
+; ?
+
+
+
+
+
+4 ?
+
+
+
+
+
+# +
+
+O X
+
+c n
+
+
+
+
+
+
++ @
+
+* -
+
+
+
+
+
+- :
+
+H L
+
+
+
+
+ !
+
+* -
+
+
+
+
+
+G K
+
+D H
+
+L `
+
+
+
+
+
+
++ I
+
+
+
+
+
+
+0 4
+
+
+
+ !
+
+
+
+
+
+
+
+ .
+
+
+
+
+
+1 =
+
+, /
+
+D H
+
+- 1
+
+Z ^
+
+( ,
+
+. 2
+
+4 <
+
+1 9
+
+/ 3
+
+5 <
+
+
+
+
+
+
+
+
+" =
+
+# &
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+B I
+
+
+
+
+
+ #
+
+D G
+
+J W
+
+2 6
+
+[ _
+
+. 9
+
+
+
+* -
+
+F N
+
+
+
+
+
+) S
+
+# '
+
+( 9
+
+ #
+
++ R
+
+8 ;
+
+F n
+
+
+
+0 1
+
+! (
+
+
+
+
+
+8 D
+
+, /
+
+D H
+
+
+
+- 1
+
+Z ^
+
+# '
+
+' *
+
+; R
+
+. 1
+
+
+
+
+
+8 ;
+
+
+
+
+
+3 H
+
+
+
+
+
+$ %
+
+( 0
+
+ &
+
+
+
++ 5
+
+; ?
+
+
+
+0 <
+
+> N
+
+
+
+
+
+1 9
+
+
+
+
+ $
+
+8 H
+
+
+
+
+
+" ,
+
+
+
+? A
+
+ %
+
+ &
+
+
+
+" #
+
+% 0
+
+ 0
+
+
+
+
+
+' 8
+
+
+
+
+
++ .
+
+5 7
+
+4 5
+
+P T
+
+V Z
+
+3 7
+
+V d
+
+
+
+
+
+& .
+
+
+
+
+
+
+
+ ,
+
+
+
+
+
+# 4
+
+
+
+
+
+' *
+
+1 3
+
+0 1
+
+L P
+
+R V
+
+
+
+
+
+
+> I
+
+
+
+@ B
+
+
+
+
+
+
+
+
+8 <
+
+D O
+
+8 ?
+
+
+
+
+
+
+
+
+
+
+9 D
+
+
+
+; <
+
+
+
+
+
+ '
+
+; B
+
+
+
+
+
+
+
+ $
+
+
+
+\ a
+
+e z
+
+
+
+
+
+
+
+
+
+
+# *
+
+ #
+
++ /
+
+C H
+
+& ,
+
+
+
+
+
+
+
+
+
+
\ No newline at end of file
diff --git a/src/src/build/sonar/scanner-report/syntax-highlightings-44.pb b/src/src/build/sonar/scanner-report/syntax-highlightings-44.pb
new file mode 100644
index 0000000..a162df5
--- /dev/null
+++ b/src/src/build/sonar/scanner-report/syntax-highlightings-44.pb
@@ -0,0 +1,139 @@
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+!!
+
+##
+##
+##
+##) 0
+$$
+
+$$
+$$
+$$/ 2
+**
+
+**
+**
+**
+**2 3
+++
+
+++
+++
+++
+++2 3
+,,
+
+,,
+,,
+,,
+,,2 3
+..
+..
+..
+..& :
+00
+11
+
+11
+11+ .
+22 "
+44
+44
+44
+77, 0
+88
+<<
+<<6 9
+==
+??( 1
+??L Q
+@@
+AA
+DD
+DD
+DDN Q
+DDc k
+EE8 =
+HH
+HH
+HHL O
+II
+JJ
+JJ
+JJ
+JJ7 B
+KK
+LL
+MM! #
+NN #
+NNE J
+OOA Y
+TT
+TT
+TT3 A
+UU
+UU' (
+VV# J
+XX
+YY
+^^
+^^
+cc
+cc
+gg! $
+jl
+mm. 2
+nn
+qqX [
+rr7 <
+ss
+
+
+
++ .
+
+
+
+
+
+
+
+
+
+
+
+
\ No newline at end of file
diff --git a/src/src/build/sonar/scanner-report/syntax-highlightings-45.pb b/src/src/build/sonar/scanner-report/syntax-highlightings-45.pb
new file mode 100644
index 0000000..10950b2
--- /dev/null
+++ b/src/src/build/sonar/scanner-report/syntax-highlightings-45.pb
@@ -0,0 +1,39 @@
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+# *
+
+
+
+
+M P
+b i
+
+!!
+""
+""
+##
+&&
+''
+''
+''" %
+((
+++
+,,
+,,
+--
\ No newline at end of file
diff --git a/src/src/build/sonar/scanner-report/syntax-highlightings-46.pb b/src/src/build/sonar/scanner-report/syntax-highlightings-46.pb
new file mode 100644
index 0000000..131718d
--- /dev/null
+++ b/src/src/build/sonar/scanner-report/syntax-highlightings-46.pb
@@ -0,0 +1,37 @@
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+# *
+
+
+
+
+M P
+
+!!
+!!
+""
+%%
+&&
+&&
+&&" %
+''
+**
+++
+++
+,,
\ No newline at end of file
diff --git a/src/src/build/sonar/scanner-report/syntax-highlightings-47.pb b/src/src/build/sonar/scanner-report/syntax-highlightings-47.pb
new file mode 100644
index 0000000..e53d604
--- /dev/null
+++ b/src/src/build/sonar/scanner-report/syntax-highlightings-47.pb
@@ -0,0 +1,33 @@
+
+
+
+
+
+
+ $
+$ &
+
+
+
+
+
+ D
+D E
+
+
+ $
+% 2
+3 >
+> A
+
+
+ %
+& 3
+4 ?
+? B
+
+
+ !
+! $
+
+
\ No newline at end of file
diff --git a/src/src/build/sonar/scanner-report/syntax-highlightings-48.pb b/src/src/build/sonar/scanner-report/syntax-highlightings-48.pb
new file mode 100644
index 0000000..4c8661a
--- /dev/null
+++ b/src/src/build/sonar/scanner-report/syntax-highlightings-48.pb
@@ -0,0 +1,21 @@
+
+
+
+
+
+
+ $
+$ &
+
+
+
+
+
+ D
+D E
+
+
+ !
+! $
+
+
\ No newline at end of file
diff --git a/src/src/build/sonar/scanner-report/syntax-highlightings-49.pb b/src/src/build/sonar/scanner-report/syntax-highlightings-49.pb
new file mode 100644
index 0000000..31c7706
--- /dev/null
+++ b/src/src/build/sonar/scanner-report/syntax-highlightings-49.pb
@@ -0,0 +1,28 @@
+
+
+
+
+
+
+ $
+$ &
+
+
+
+
+
+ D
+D E
+
+
+
+ &
+
+ 5
+5 8
+
+
+ 4
+4 7
+
+
\ No newline at end of file
diff --git a/src/src/build/sonar/scanner-report/syntax-highlightings-5.pb b/src/src/build/sonar/scanner-report/syntax-highlightings-5.pb
new file mode 100644
index 0000000..8cbba8a
--- /dev/null
+++ b/src/src/build/sonar/scanner-report/syntax-highlightings-5.pb
@@ -0,0 +1,357 @@
+
+
+
+
+
+
+
+
+
+
+
+
+
+
++ 9
+
+
+
+
+% ,
+
+
+
+
+
+, -
+
+
+
+
+
+, -
+
+
+
+
+
+, -
+
+!!
+
+!!
+!!
+!!
+!!- .
+""
+
+""
+""
+""
+""2 3
+##
+
+##
+##
+##
+##5 6
+$$
+
+$$
+$$
+$$
+$$. /
+&&
+
+&&
+&&
+&&9 V
+''
+
+''
+''
+''< b
+((
+
+((
+((
+((8 T
+))
+
+))
+))
+)): X
+**
+
+**
+**
+**8 T
+++
+
+++
+++
+++8 T
+--
+
+--
+--
+--
+--9 :
+..
+
+..
+..
+..
+..8 9
+//
+
+//
+//
+//
+//8 9
+00
+
+00
+00
+00) 5
+11
+
+11
+11
+22
+22
+22
+33
+33
+33
+68
+99
+
+99
+99
+99O V
+;=
+>>
+
+>>
+>>
+>>O V
+@@
+
+@@
+BB
+CC
+DD )
+EH
+II
+KN
+OO &
+QT
+UU ,
+WZ
+[[ .
+^a
+bb *
+dg
+hh #
+jm
+nn '
+ps
+tt +
+vy
+zz +
+ |
+
+! 1
+
+
+
+ +
+
+
+
+
+
+
+
+ #
+
+
+
+! 1
+
+
+
+" 4
+
+
+
+ %
+
+
+
+ #
+
+
+
+
+
+
+
+
+
+
+
+
+ '
+
+
+
+ #
+
+
+
+ -
+
+
+
+ /
+
+
+
+ #
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+' 1
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+2 3
+
+
+
+
+
+
+
+
+
+4 5
+6
+
+
+
+
+
+
+
+2 T
+
+
+
+
+
+
+
+7 Z
+
+
+
+
+
+
+
+N Z
+
+
+
+
+
+
+
+
+
+
+' 1
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+2 T
+
+
+
+
+
+
+
+7 Z
+
+
+
+
+
+
+
+N Z
\ No newline at end of file
diff --git a/src/src/build/sonar/scanner-report/syntax-highlightings-6.pb b/src/src/build/sonar/scanner-report/syntax-highlightings-6.pb
new file mode 100644
index 0000000..36bb0c3
--- /dev/null
+++ b/src/src/build/sonar/scanner-report/syntax-highlightings-6.pb
@@ -0,0 +1,583 @@
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ ! (
+!!
+!!
+!!
+!!* 3
+##
+##
+##
+##
+##* +
+%%
+
+%%
+&&
+((
+++
+++
+++
+++& ;
+--
+--
+//
+//
+//
+00
+00' *
+11 4
+22$ B
+33' E
+44& D
+55' a
+66) G
+77( b
+88& D
+99" >
+:: =
+;;$ B
+<<& E
+==" @
+>>) G
+??+ I
+@@# ?
+AA" @
+BB# ?
+BBA J
+CC ;
+CC< G
+DD
+FF
+FF
+FF
+GG
+GG' *
+HH 4
+II$ 5
+JJ" @
+KK' a
+LL( b
+MM" >
+NN +
+OO +
+PP <
+QQ <
+RR ;
+SS
+UU
+UU
+UU
+VV 6
+WW
+WW1 5
+Y[
+\\
+\\
+\\
+]] 9
+^^
+^^6 <
+__
+``
+aa
+aa. 1
+aaN T
+bb
+bb& -
+bbH K
+cc
+eg
+hh
+hh
+hh
+ii 9
+jj
+jj6 <
+kk
+ll
+mm
+mm. 1
+mmN R
+nn
+nn& -
+oo
+oo- 1
+oo4 7
+pp
+rt
+uu
+uu
+uu
+vv 9
+ww
+xx
+yy
+zz
+zz. 1
+zzN T
+{{
+{{& -
+{{H K
+||
+ ~
+
+
+
+
+
+
+
+ 9
+
+
+
+
+
+
+
+
+
+. 1
+
+N R
+
+
+
+& -
+
+
+
+- 2
+
+
+
+
+
+
+
+
+
+
+
+ 7
+
+
+
+
+
+/ 3
+
+K N
+
+
+
+
+
+
+
+* 1
+
+
+
+& -
+
+F I
+
+
+
+
+
+
+
+
+
+
+
+ 7
+
+
+
+
+
+/ 3
+
+K N
+
+
+
+
+
+
+
+* 1
+
+
+
+& -
+
+F I
+
+
+
+
+
+
+
+
+
+
+
+ 7
+
+
+
+
+
+/ 3
+
+K N
+
+
+
+
+
+
+
+* /
+
+
+
+& -
+
+F I
+
+
+
+
+
+
+
+
+
+
+
+ /
+
+
+
+
+
+
+
+
+
+, 3
+
+G J
+
+
+
+
+
+
+
+
+
+
+
+ 7
+
+
+
+
+
+
+
+
+
+. 5
+
+I L
+
+
+
+
+
+
+
+
+
+
+
+ 4
+
+
+
+
+
+/ 2
+
+
+
+
+
+
+
+, /
+
+
+
+- 4
+
+H K
+
+
+
+
+
+
+
+
+ $
+
+
+
+
+
+
+ 0
+
+
+
+
+
+ K
+
+ K
+
+ K
+
+ A
+
+ K
+
+ I
+
+ F
+
+
+
+
+
+
+- @
+
+
+
+" 2
+
+B X
+
+[ _
+
+o s
+
+ &
+
+. 2
+
+
+
+
+
+
+
+
+H Q
+
+B G
+
+
+
+
+
+ "
+
+
+
+ "
+
+
+
+ "
+
+
+
+ "
+
+
+
+ "
+
+
+
+
+
+
+ 0
+
+
+
+
+
+ I
+
+ I
+
+ I
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+- 0
+
+= @
+
+
+
+# (
+
+
+
+
+
+
+
+
+
+
+
+
+ N
+
+
+
+
+
+
+ #
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+, P
+
+
+
+
+
+
+
+ *
+
+ *
+
+
+
+
+
+
+
+ O
+
+ O
+
+ O
+
+ $
+
+ !
+
+1 ?
+
+ -
+
+ $
+
+ "
+
+ "
+
+
+
+
+
+ !
+
+1 ?
+
+ /
\ No newline at end of file
diff --git a/src/src/build/sonar/scanner-report/syntax-highlightings-7.pb b/src/src/build/sonar/scanner-report/syntax-highlightings-7.pb
new file mode 100644
index 0000000..a5e07df
--- /dev/null
+++ b/src/src/build/sonar/scanner-report/syntax-highlightings-7.pb
@@ -0,0 +1,486 @@
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+!!
+
+""
+
+##
+
+&&
+&&
+&& "
+''
+''
+''
+))
+++
+++
+++
+++& 5
+--
+--
+--
+--
+--3 4
+..
+..
+..
+..
+..3 4
+//
+//
+//
+//
+//3 4
+00
+00
+00
+00
+003 4
+22
+22
+22
+22
+223 4
+33
+33
+33
+33
+333 4
+55
+
+66
+77) /
+88) 1
+99) /
+::) 1
+;;) 1
+==P T
+@C
+DD
+DD
+DD
+DDK N
+EE !
+EEU X
+FF
+
+FF2 D
+FFm p
+GG
+
+GG2 D
+GGm p
+HH% +
+HHT W
+II
+
+II% ,
+II\ _
+JJ
+
+JJ. 5
+LL
+LL
+LL7 @
+MM
+
+NN
+
+NN, 5
+OO
+
+OO, 0
+PP
+
+PP' *
+RR
+SS
+
+SS
+UU
+UU
+XX
+YY
+
+[[
+]]
+^^
+__
+``O S
+``U Y
+bb
+cc
+dd/ 0
+eeF I
+ffD H
+ffJ N
+gg
+hh
+iiO S
+iiU Y
+kk
+ll
+mm/ 0
+nnF I
+ooD H
+ooJ N
+pp
+qq
+rr
+ss
+ss! %
+ss7 ;
+tt
+tt
+uu _
+uub s
+xx& *
+yy
+zz
+zz7 8
+{{A B
+}}
+~~9 B
+
+
+
+
+
+
+
+
+
+1 9
+
+
+
+
+
+ 0
+
+
+
+
+
+
+
+
+
+3 A
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+" #
+
+2 3
+
+
+
+
+
+< @
+
+
+
+
+
+
+
+
+
+ C
+
+< @
+
+
+
+
+
+
+
+
+
+3 A
+
+
+
+
+
+
+
+
+P T
+
+
+
+
+
+
+
+
+P T
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ "
+
+
+
+
+
+
+
+. 6
+
+J O
+
+
+
+
+
+/ 0
+
+
+
+
+
+
+
+
+
+
+
+) ,
+
+
+
+
+
+ !
+
+
+
+
+
+/ 0
+
+) ,
+
+ !
+
+
+
+
+
+
+
+
+
+3 A
+
+
+
+
+
+
+
+
+W [
+
+@ D
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ "
+
+
+
+
+
+% &
+
+
+
+
+
+/ 0
+
+G J
+
+
+
+
+
+ !
+
+
+
+
+
+/ 0
+
+G J
+
+ !
+
+
+
+
+
+
+
+
+
+3 A
+
+
+
+
+
+
+
+
+W [
+
+@ D
+
+
+
+
+
+
+
+0 8
+
+G J
+
+M O
+
+
+
+
+
+% )
+
+
+
+. 1
+
+
+
+
+
+
+
+/ 4
+
+
+
+
+
+
+
+
+
+
+
+
+
+( +
+
+
+
+
+' (
+
+
+
+9 >
+
+
+
+
+
+
+ *
+
+
+
+
\ No newline at end of file
diff --git a/src/src/build/sonar/scanner-report/syntax-highlightings-8.pb b/src/src/build/sonar/scanner-report/syntax-highlightings-8.pb
new file mode 100644
index 0000000..3fe22ad
--- /dev/null
+++ b/src/src/build/sonar/scanner-report/syntax-highlightings-8.pb
@@ -0,0 +1,75 @@
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+/ 4
+
+! %
+!!
+
+!!
+""
+$$
+
+%% 2
+++
+
+,,
+//
+00
+
+00
+11
+11 !
+44
+55
+
+55
+66
+77
+
+77
+88
+99& )
+;;
+<< 6
+== "
+BB
+CC
+
+CC
+DD -
+EE
+EE
+EE% Z
+HH
+II
+
+JJ
+JJ
+JJ% \
+MM
+NN
+
+NN
+OO
+OO
+OO% R
\ No newline at end of file
diff --git a/src/src/build/sonar/scanner-report/syntax-highlightings-9.pb b/src/src/build/sonar/scanner-report/syntax-highlightings-9.pb
new file mode 100644
index 0000000..c77c23a
--- /dev/null
+++ b/src/src/build/sonar/scanner-report/syntax-highlightings-9.pb
@@ -0,0 +1,138 @@
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+/ 0
+
+
+
+
+
+5 6
+
+
+
+
+
+4 5
+
+
+
+
+
+5 6
+
+
+
+
+
+ 4 5
+""
+
+""
+""
+""
+""8 9
+$$
+
+$$
+$$
+$$
+$$7 8
+&&
+
+&&
+&&
+&&
+&&: ;
+((
+
+((
+((
+((
+((0 1
+**
+,,
+..
+..
+00
+00
+22
+
+33
+44
+55
+66
+99
+
+99
+99/ 2
+;;
+
+;;
+;;/ 2
+==
+
+==
+==
+??
+
+??
+??
+AA
+
+AA
+CC
+
+CC
+CC
+EE
+
+EE
+FF
+II
+
+II
+JJ
+MM
+
+MM
+MM $
+NN
+QQ
+
+QQ
+QQ "
+RR
+UU
+
+VV
+VV
+YY
+
+ZZ
+ZZ
+]]
+
+]]
+^^
+^^
+aa
+
+aa
+bb
+bb
\ No newline at end of file
diff --git a/src/src/gradle.properties b/src/src/gradle.properties
new file mode 100644
index 0000000..d015431
--- /dev/null
+++ b/src/src/gradle.properties
@@ -0,0 +1,2 @@
+android.useAndroidX=true
+android.enableJetifier=true
\ No newline at end of file
diff --git a/src/src/gradle/wrapper/gradle-wrapper.jar b/src/src/gradle/wrapper/gradle-wrapper.jar
new file mode 100644
index 0000000..f6b961f
Binary files /dev/null and b/src/src/gradle/wrapper/gradle-wrapper.jar differ
diff --git a/src/src/gradle/wrapper/gradle-wrapper.properties b/src/src/gradle/wrapper/gradle-wrapper.properties
new file mode 100644
index 0000000..f9772b4
--- /dev/null
+++ b/src/src/gradle/wrapper/gradle-wrapper.properties
@@ -0,0 +1,6 @@
+#Sun Sep 20 00:54:46 CST 2020
+distributionBase=GRADLE_USER_HOME
+distributionPath=wrapper/dists
+zipStoreBase=GRADLE_USER_HOME
+zipStorePath=wrapper/dists
+distributionUrl=https://services.gradle.org/distributions/gradle-6.1.1-all.zip
diff --git a/src/src/gradlew b/src/src/gradlew
new file mode 100644
index 0000000..cccdd3d
--- /dev/null
+++ b/src/src/gradlew
@@ -0,0 +1,172 @@
+#!/usr/bin/env sh
+
+##############################################################################
+##
+## Gradle start up script for UN*X
+##
+##############################################################################
+
+# Attempt to set APP_HOME
+# Resolve links: $0 may be a link
+PRG="$0"
+# Need this for relative symlinks.
+while [ -h "$PRG" ] ; do
+ ls=`ls -ld "$PRG"`
+ link=`expr "$ls" : '.*-> \(.*\)$'`
+ if expr "$link" : '/.*' > /dev/null; then
+ PRG="$link"
+ else
+ PRG=`dirname "$PRG"`"/$link"
+ fi
+done
+SAVED="`pwd`"
+cd "`dirname \"$PRG\"`/" >/dev/null
+APP_HOME="`pwd -P`"
+cd "$SAVED" >/dev/null
+
+APP_NAME="Gradle"
+APP_BASE_NAME=`basename "$0"`
+
+# Add default JVM options here. You can also use JAVA_OPTS and GRADLE_OPTS to pass JVM options to this script.
+DEFAULT_JVM_OPTS=""
+
+# Use the maximum available, or set MAX_FD != -1 to use that value.
+MAX_FD="maximum"
+
+warn () {
+ echo "$*"
+}
+
+die () {
+ echo
+ echo "$*"
+ echo
+ exit 1
+}
+
+# OS specific support (must be 'true' or 'false').
+cygwin=false
+msys=false
+darwin=false
+nonstop=false
+case "`uname`" in
+ CYGWIN* )
+ cygwin=true
+ ;;
+ Darwin* )
+ darwin=true
+ ;;
+ MINGW* )
+ msys=true
+ ;;
+ NONSTOP* )
+ nonstop=true
+ ;;
+esac
+
+CLASSPATH=$APP_HOME/gradle/wrapper/gradle-wrapper.jar
+
+# Determine the Java command to use to start the JVM.
+if [ -n "$JAVA_HOME" ] ; then
+ if [ -x "$JAVA_HOME/jre/sh/java" ] ; then
+ # IBM's JDK on AIX uses strange locations for the executables
+ JAVACMD="$JAVA_HOME/jre/sh/java"
+ else
+ JAVACMD="$JAVA_HOME/bin/java"
+ fi
+ if [ ! -x "$JAVACMD" ] ; then
+ die "ERROR: JAVA_HOME is set to an invalid directory: $JAVA_HOME
+
+Please set the JAVA_HOME variable in your environment to match the
+location of your Java installation."
+ fi
+else
+ JAVACMD="java"
+ which java >/dev/null 2>&1 || die "ERROR: JAVA_HOME is not set and no 'java' command could be found in your PATH.
+
+Please set the JAVA_HOME variable in your environment to match the
+location of your Java installation."
+fi
+
+# Increase the maximum file descriptors if we can.
+if [ "$cygwin" = "false" -a "$darwin" = "false" -a "$nonstop" = "false" ] ; then
+ MAX_FD_LIMIT=`ulimit -H -n`
+ if [ $? -eq 0 ] ; then
+ if [ "$MAX_FD" = "maximum" -o "$MAX_FD" = "max" ] ; then
+ MAX_FD="$MAX_FD_LIMIT"
+ fi
+ ulimit -n $MAX_FD
+ if [ $? -ne 0 ] ; then
+ warn "Could not set maximum file descriptor limit: $MAX_FD"
+ fi
+ else
+ warn "Could not query maximum file descriptor limit: $MAX_FD_LIMIT"
+ fi
+fi
+
+# For Darwin, add options to specify how the application appears in the dock
+if $darwin; then
+ GRADLE_OPTS="$GRADLE_OPTS \"-Xdock:name=$APP_NAME\" \"-Xdock:icon=$APP_HOME/media/gradle.icns\""
+fi
+
+# For Cygwin, switch paths to Windows format before running java
+if $cygwin ; then
+ APP_HOME=`cygpath --path --mixed "$APP_HOME"`
+ CLASSPATH=`cygpath --path --mixed "$CLASSPATH"`
+ JAVACMD=`cygpath --unix "$JAVACMD"`
+
+ # We build the pattern for arguments to be converted via cygpath
+ ROOTDIRSRAW=`find -L / -maxdepth 1 -mindepth 1 -type d 2>/dev/null`
+ SEP=""
+ for dir in $ROOTDIRSRAW ; do
+ ROOTDIRS="$ROOTDIRS$SEP$dir"
+ SEP="|"
+ done
+ OURCYGPATTERN="(^($ROOTDIRS))"
+ # Add a user-defined pattern to the cygpath arguments
+ if [ "$GRADLE_CYGPATTERN" != "" ] ; then
+ OURCYGPATTERN="$OURCYGPATTERN|($GRADLE_CYGPATTERN)"
+ fi
+ # Now convert the arguments - kludge to limit ourselves to /bin/sh
+ i=0
+ for arg in "$@" ; do
+ CHECK=`echo "$arg"|egrep -c "$OURCYGPATTERN" -`
+ CHECK2=`echo "$arg"|egrep -c "^-"` ### Determine if an option
+
+ if [ $CHECK -ne 0 ] && [ $CHECK2 -eq 0 ] ; then ### Added a condition
+ eval `echo args$i`=`cygpath --path --ignore --mixed "$arg"`
+ else
+ eval `echo args$i`="\"$arg\""
+ fi
+ i=$((i+1))
+ done
+ case $i in
+ (0) set -- ;;
+ (1) set -- "$args0" ;;
+ (2) set -- "$args0" "$args1" ;;
+ (3) set -- "$args0" "$args1" "$args2" ;;
+ (4) set -- "$args0" "$args1" "$args2" "$args3" ;;
+ (5) set -- "$args0" "$args1" "$args2" "$args3" "$args4" ;;
+ (6) set -- "$args0" "$args1" "$args2" "$args3" "$args4" "$args5" ;;
+ (7) set -- "$args0" "$args1" "$args2" "$args3" "$args4" "$args5" "$args6" ;;
+ (8) set -- "$args0" "$args1" "$args2" "$args3" "$args4" "$args5" "$args6" "$args7" ;;
+ (9) set -- "$args0" "$args1" "$args2" "$args3" "$args4" "$args5" "$args6" "$args7" "$args8" ;;
+ esac
+fi
+
+# Escape application args
+save () {
+ for i do printf %s\\n "$i" | sed "s/'/'\\\\''/g;1s/^/'/;\$s/\$/' \\\\/" ; done
+ echo " "
+}
+APP_ARGS=$(save "$@")
+
+# Collect all arguments for the java command, following the shell quoting and substitution rules
+eval set -- $DEFAULT_JVM_OPTS $JAVA_OPTS $GRADLE_OPTS "\"-Dorg.gradle.appname=$APP_BASE_NAME\"" -classpath "\"$CLASSPATH\"" org.gradle.wrapper.GradleWrapperMain "$APP_ARGS"
+
+# by default we should be in the correct project dir, but when run from Finder on Mac, the cwd is wrong
+if [ "$(uname)" = "Darwin" ] && [ "$HOME" = "$PWD" ]; then
+ cd "$(dirname "$0")"
+fi
+
+exec "$JAVACMD" "$@"
diff --git a/src/src/gradlew.bat b/src/src/gradlew.bat
new file mode 100644
index 0000000..f955316
--- /dev/null
+++ b/src/src/gradlew.bat
@@ -0,0 +1,84 @@
+@if "%DEBUG%" == "" @echo off
+@rem ##########################################################################
+@rem
+@rem Gradle startup script for Windows
+@rem
+@rem ##########################################################################
+
+@rem Set local scope for the variables with windows NT shell
+if "%OS%"=="Windows_NT" setlocal
+
+set DIRNAME=%~dp0
+if "%DIRNAME%" == "" set DIRNAME=.
+set APP_BASE_NAME=%~n0
+set APP_HOME=%DIRNAME%
+
+@rem Add default JVM options here. You can also use JAVA_OPTS and GRADLE_OPTS to pass JVM options to this script.
+set DEFAULT_JVM_OPTS=
+
+@rem Find java.exe
+if defined JAVA_HOME goto findJavaFromJavaHome
+
+set JAVA_EXE=java.exe
+%JAVA_EXE% -version >NUL 2>&1
+if "%ERRORLEVEL%" == "0" goto init
+
+echo.
+echo ERROR: JAVA_HOME is not set and no 'java' command could be found in your PATH.
+echo.
+echo Please set the JAVA_HOME variable in your environment to match the
+echo location of your Java installation.
+
+goto fail
+
+:findJavaFromJavaHome
+set JAVA_HOME=%JAVA_HOME:"=%
+set JAVA_EXE=%JAVA_HOME%/bin/java.exe
+
+if exist "%JAVA_EXE%" goto init
+
+echo.
+echo ERROR: JAVA_HOME is set to an invalid directory: %JAVA_HOME%
+echo.
+echo Please set the JAVA_HOME variable in your environment to match the
+echo location of your Java installation.
+
+goto fail
+
+:init
+@rem Get command-line arguments, handling Windows variants
+
+if not "%OS%" == "Windows_NT" goto win9xME_args
+
+:win9xME_args
+@rem Slurp the command line arguments.
+set CMD_LINE_ARGS=
+set _SKIP=2
+
+:win9xME_args_slurp
+if "x%~1" == "x" goto execute
+
+set CMD_LINE_ARGS=%*
+
+:execute
+@rem Setup the command line
+
+set CLASSPATH=%APP_HOME%\gradle\wrapper\gradle-wrapper.jar
+
+@rem Execute Gradle
+"%JAVA_EXE%" %DEFAULT_JVM_OPTS% %JAVA_OPTS% %GRADLE_OPTS% "-Dorg.gradle.appname=%APP_BASE_NAME%" -classpath "%CLASSPATH%" org.gradle.wrapper.GradleWrapperMain %CMD_LINE_ARGS%
+
+:end
+@rem End local scope for the variables with windows NT shell
+if "%ERRORLEVEL%"=="0" goto mainEnd
+
+:fail
+rem Set variable GRADLE_EXIT_CONSOLE if you need the _script_ return code instead of
+rem the _cmd.exe /c_ return code!
+if not "" == "%GRADLE_EXIT_CONSOLE%" exit 1
+exit /b 1
+
+:mainEnd
+if "%OS%"=="Windows_NT" endlocal
+
+:omega
diff --git a/src/src/import-summary.txt b/src/src/import-summary.txt
new file mode 100644
index 0000000..366cc98
--- /dev/null
+++ b/src/src/import-summary.txt
@@ -0,0 +1,36 @@
+ECLIPSE ANDROID PROJECT IMPORT SUMMARY
+=====================================
+
+Ignored Files:
+--------------
+The following files were *not* copied into the new Gradle project; you
+should evaluate whether these are still needed in your project and if
+so manually move them:
+
+* .gitignore
+* NOTICE
+* README
+
+Moved Files:
+------------
+Android Gradle projects use a different directory structure than ADT
+Eclipse projects. Here's how the projects were restructured:
+
+* AndroidManifest.xml => app\src\main\AndroidManifest.xml
+* res\ => app\src\main\res\
+* src\ => app\src\main\java\
+
+Next Steps:
+-----------
+You can now build the project. The Gradle project needs network
+connectivity to download dependencies.
+
+Bugs:
+-----
+If for some reason your project does not build, and you determine that
+it is due to a bug or limitation of the Eclipse to Gradle importer,
+please file a bug at http://b.android.com with category
+Component-Tools.
+
+(This import summary is for your information only, and can be deleted
+after import once you are satisfied with the results.)
diff --git a/src/src/local.properties b/src/src/local.properties
new file mode 100644
index 0000000..4204178
--- /dev/null
+++ b/src/src/local.properties
@@ -0,0 +1,8 @@
+## This file must *NOT* be checked into Version Control Systems,
+# as it contains information specific to your local configuration.
+#
+# Location of the SDK. This is only used by Gradle.
+# For customization when using a Version Control System, please read the
+# header note.
+#Sun Feb 21 23:40:54 CST 2021
+sdk.dir=E\:\\androidEnviroment
diff --git a/src/src/settings.gradle b/src/src/settings.gradle
new file mode 100644
index 0000000..e7b4def
--- /dev/null
+++ b/src/src/settings.gradle
@@ -0,0 +1 @@
+include ':app'