File: tail_rec

package info (click to toggle)
erlang 1%3A15.b.1-dfsg-4%2Bdeb7u1
  • links: PTS, VCS
  • area: main
  • in suites: wheezy
  • size: 210,320 kB
  • sloc: erlang: 1,325,533; xml: 338,134; ansic: 283,913; cpp: 48,667; makefile: 23,010; sh: 12,077; java: 10,102; lisp: 7,918; python: 5,298; pascal: 3,263; asm: 2,774; perl: 2,718; tcl: 245; sed: 48
file content (25 lines) | stat: -rwxr-xr-x 616 bytes parent folder | download | duplicates (15)
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
#!/usr/bin/env escript
%% -*- erlang -*-
-mode(interpret).

tail_rec(PrevSize, N) ->
    {_, Size} = process_info(self(), stack_size),
    if
	N =< 0 ->
	    ok;
	PrevSize =:= undefined ->
	    tail_rec(Size, N - 1);
	PrevSize =:= Size ->
	    tail_rec(Size, N - 1);
	true ->
	    io:format("Not tail recursive (~p): Stack size ~p should be ~p\n",
		      [N, Size, PrevSize]),
	    tail_rec(Size, N - 1)
    end.

main([Repetitions]) ->
    tail_rec(undefined, list_to_integer(Repetitions)),
    io:format("ok\n", []);
main(_) ->
    io:format("Usage: ~s Repetitions\n", [escript:script_name()]),
    init:stop(1).