-
Notifications
You must be signed in to change notification settings - Fork 11
/
Copy pathTODO
64 lines (41 loc) · 1.81 KB
/
TODO
1
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
• PASS more tests
• Str/Buf/Blob - binary data (+ tests)
Current thought: remove the meaning of "binary" as currently is
implemented, as everything is valid Str already.
Add binary support by allowing *real* binary (images, raw data)
by adding a Blob entry in CSV::Field and use that instead of the
current Str $.text by using CATCH blocks.
When fetching the field, check if Buf is set and return that (if
possible)
Str = String of characters
Buf = Mutable buffer for binary data
Blob = Common interface for binary large objects
• csv () function
• Documentation
• Speed
Once Regexes are "fast" again, and $!eol can be embedded in $chx,
re-enable the ~~ $eol again. For now disable the use of Regex in
eol attribute.
new (eol => Str, # supported
new (eol => "\n", # supported
new (eol => "\r\n", # supported
new (eol => rx{ \s* \r?\n }, # future
• Decide if types should be dealt with beyond current overloading
Also of possible impact to Text::CSV.list
See use of hashes (_hr)
Decide if $!meta should be an attribute again, so .list and .fields
can merge. Mind csv () and fragment ("cells="...")
• bind_columns and hashes
If returning hashes, consider if returning Str:Str kv pairs is
the way to go instead of Str:CSV::Field. If so, then column types
might be useful again.
• merge masak's Text::CSV
:strict
Throw an error if a row has a different number of columns than
the previous ones.
:trim
Removes whitespace on both ends of each value.Currently implemented
as :allow-whitespace, but that does not trim inside quotation
:skip-header
Causes the first line not to be included in the output. Function &
method csv () already supports headers => "skip" (NYI)