Ich denke, das ist ein Fehler in der formatting module, die sich um schönes Drucken auf F # Interactive kümmert.
Es gibt einige nicht-tail rekursive Funktionen, die PrintLength
z. in diesem line. Die Umsetzung von boundedUnfoldL
ist in der Tat nicht Schwanz-rekursive:
let boundedUnfoldL
(itemL : 'a -> layout)
(project : 'z -> ('a * 'z) option)
(stopShort : 'z -> bool)
(z : 'z)
maxLength =
let rec consume n z =
if stopShort z then [wordL "..."] else
match project z with
| None -> [] // exhaused input
| Some (x,z) -> if n<=0 then [wordL "..."] // hit print_length limit
else itemL x :: consume (n-1) z // cons recursive...
consume maxLength z
Ich weiß nicht, warum es auf Mono nicht sprengen. Es wäre überraschend, wenn F # Interactive on Mono die Länge> 5000 erfolgreich bewältigen könnte.
Sie können dies als einen Fehler an https://visualfsharp.codeplex.com/workitem/list/basic melden.
Klingt wie die F # Interactive profitieren würde von https://fslang.uservoice.com/forums/245727-f-language/suggestions/5663074-enable-a-compiler-warning-when-a-recursive-algorit – Asik