Blame SOURCES/0219-augeas-trim-spaces-on-eol-around-value-separator.patch

28bab8
From 3fc1e286151e12b3229750da7a550b8f799a35bc Mon Sep 17 00:00:00 2001
28bab8
From: Julius Milan <jmilan@redhat.com>
28bab8
Date: Wed, 22 Mar 2017 14:10:04 +0100
28bab8
Subject: [PATCH] augeas: trim spaces on eol, around value separator
28bab8
28bab8
Resolves abrt/libreport#474
28bab8
Related to rhbz#1435256
28bab8
---
28bab8
 augeas/libreport.aug      | 19 ++++++++++++-------
28bab8
 augeas/test_libreport.aug | 20 ++++++++++++++++++++
28bab8
 2 files changed, 32 insertions(+), 7 deletions(-)
28bab8
28bab8
diff --git a/augeas/libreport.aug b/augeas/libreport.aug
28bab8
index 7125be2..76b3bcc 100644
28bab8
--- a/augeas/libreport.aug
28bab8
+++ b/augeas/libreport.aug
28bab8
@@ -2,19 +2,24 @@ module Libreport =
28bab8
     autoload xfm
28bab8
 
28bab8
     (* Define useful primitives *)
28bab8
-    let value_sep    = del / ?= ?/ " = "
28bab8
-    let value_to_eol = store /([^ \t\n].*[^ \t\n]|[^ \t\n]?)/
28bab8
-    let eol          = del /\n/ "\n"
28bab8
-    let ident        = /[a-zA-Z][a-zA-Z_]+/
28bab8
+    let val_sep        = del /[ \t]*=[ \t]*/ " = "
28bab8
+    let val            = store /([^ \t\n].*[^ \t\n]|[^ \t\n])/
28bab8
+    let eol            = del /\n/ "\n"
28bab8
+    let whitespace_eol = del /[ \t]*\n/ "\n"
28bab8
+    let ident          = /[a-zA-Z][a-zA-Z_]+/
28bab8
 
28bab8
     (* Define comment *)
28bab8
-    let comment = [ label "#comment" . del /#[ \t]*/ "# " . value_to_eol . eol ]
28bab8
+    let commented_line = [ label "#comment" . del /#[ \t]*/ "# " . val . eol ]
28bab8
+    let empty_comment  = [ label "#comment" . value "" . del /#[ \t]*/ "# " . eol ]
28bab8
+    let comment        = commented_line | empty_comment
28bab8
 
28bab8
     (* Define empty *)
28bab8
-    let empty = [ del /[ \t]*\n/ "\n" ]
28bab8
+    let empty          = [ del /[ \t]*\n/ "\n" ]
28bab8
 
28bab8
     (* Define option *)
28bab8
-    let option = [ del /[ \t]*/ "" . key ident . value_sep . value_to_eol . eol ]
28bab8
+    let option_val     = [ del /[ \t]*/ "" . key ident . val_sep . val . whitespace_eol ]
28bab8
+    let option_no_val  = [ value "" . del /[ \t]*/ "" . key ident . val_sep . eol ]
28bab8
+    let option         = option_val | option_no_val
28bab8
 
28bab8
     (* Define lens *)
28bab8
     let lns = ( comment | empty | option )*
28bab8
diff --git a/augeas/test_libreport.aug b/augeas/test_libreport.aug
28bab8
index 116e97c..3dfbfa6 100644
28bab8
--- a/augeas/test_libreport.aug
28bab8
+++ b/augeas/test_libreport.aug
28bab8
@@ -16,6 +16,8 @@ Password =
28bab8
 # bugs in selinux-policy component.
28bab8
 # (If you need to add more, the syntax is: \"component[,component...]\")
28bab8
 #
28bab8
+#       
28bab8
+#		
28bab8
 DontMatchComponents = selinux-policy
28bab8
 
28bab8
 # for more info about these settings see: https://github.com/abrt/abrt/wiki/FAQ#creating-private-bugzilla-tickets
28bab8
@@ -25,6 +27,14 @@ PrivateGroups=private
28bab8
   Whitespace_two=start
28bab8
 	Whitespace_three =start
28bab8
 	 Whitespace_four= start
28bab8
+
28bab8
+AssignmentWhitespace_a   =what
28bab8
+     AssignmentWhitespace_b   =    an
28bab8
+AssignmentWhitespace_c=   		 original
28bab8
+  AssignmentWhitespace_d =      idea
28bab8
+
28bab8
+EOLWhitespace_a = nice      
28bab8
+EOLWhitespace_b = nice 		 
28bab8
 "
28bab8
 
28bab8
     test Libreport.lns get conf =
28bab8
@@ -44,6 +54,8 @@ PrivateGroups=private
28bab8
         { "#comment" = "bugs in selinux-policy component." }
28bab8
         { "#comment" = "(If you need to add more, the syntax is: \"component[,component...]\")" }
28bab8
         { "#comment" = "" }
28bab8
+        { "#comment" = "" }
28bab8
+        { "#comment" = "" }
28bab8
         { "DontMatchComponents" = "selinux-policy" }
28bab8
         {}
28bab8
         { "#comment" = "for more info about these settings see: https://github.com/abrt/abrt/wiki/FAQ#creating-private-bugzilla-tickets" }
28bab8
@@ -53,3 +65,11 @@ PrivateGroups=private
28bab8
         { "Whitespace_two" = "start" }
28bab8
         { "Whitespace_three" = "start" }
28bab8
         { "Whitespace_four" = "start" }
28bab8
+        {}
28bab8
+        { "AssignmentWhitespace_a" = "what" }
28bab8
+        { "AssignmentWhitespace_b" = "an" }
28bab8
+        { "AssignmentWhitespace_c" = "original" }
28bab8
+        { "AssignmentWhitespace_d" = "idea" }
28bab8
+        {}
28bab8
+        { "EOLWhitespace_a" = "nice" }
28bab8
+        { "EOLWhitespace_b" = "nice" }
28bab8
-- 
28bab8
1.8.3.1
28bab8