]> Cypherpunks.ru repositories - gorecfile.git/commitdiff
Slightly more documentation v0.1.1
authorSergey Matveev <stargrave@stargrave.org>
Thu, 15 Oct 2020 16:05:09 +0000 (19:05 +0300)
committerSergey Matveev <stargrave@stargrave.org>
Thu, 15 Oct 2020 16:19:04 +0000 (19:19 +0300)
README
r.go

diff --git a/README b/README
index 8489c680b4a61d6637b8b6e0d94c7048c342e7ae..23f1fa334fac2b85e98f796861e7615f9f5b6879 100644 (file)
--- a/README
+++ b/README
@@ -1 +1,7 @@
-GNU recutils'es recfile parser on pure Go.
+GNU recutils'es recfile parser on pure Go. recfiles are human-editable,
+plaintext databases. This library allows you to read records and their
+fields from it. Look for cmd/gorecsel as an example usage.
+
+* iterate through the records and their fields
+* ignore comments
+* support continuation lines (\$) and multilines (^+)
diff --git a/r.go b/r.go
index 36141715f151f5b8027ac962adf692897b40b4df..9a4420d7b6968f8649c44d9ec3481227adf6896c 100644 (file)
--- a/r.go
+++ b/r.go
@@ -15,6 +15,7 @@ You should have received a copy of the GNU General Public License
 along with this program.  If not, see <http://www.gnu.org/licenses/>.
 */
 
+// GNU recutils'es recfiles parser on pure Go
 package recfile
 
 import (
@@ -25,10 +26,14 @@ import (
        "strings"
 )
 
+var KeyValRe = regexp.MustCompile(`([a-zA-Z%][a-zA-Z0-9_]*):\s*(.*)$`)
+
 type Reader struct {
        scanner *bufio.Scanner
 }
 
+// Create Reader for iterating through the records. It uses
+// bufio.Scanner, so can read more than currently parsed records take.
 func NewReader(r io.Reader) *Reader {
        return &Reader{bufio.NewScanner(r)}
 }
@@ -38,8 +43,8 @@ type Field struct {
        Value string
 }
 
-var KeyValRe = regexp.MustCompile(`([a-zA-Z%][a-zA-Z0-9_]*):\s*(.*)$`)
-
+// Get next record. Each record is just a collection of fields. io.EOF
+// is returned if there is nothing to read more.
 func (r *Reader) Next() ([]Field, error) {
        fields := make([]Field, 0, 1)
        var text string