File: tail_rec

package info (click to toggle)
erlang 1%3A27.3.4.1%2Bdfsg-1
  • links: PTS, VCS
  • area: main
  • in suites: trixie
  • size: 225,000 kB
  • sloc: erlang: 1,658,966; ansic: 405,769; cpp: 177,850; xml: 82,435; makefile: 15,031; sh: 14,401; lisp: 9,812; java: 8,603; asm: 6,541; perl: 5,836; python: 5,484; sed: 72
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).