File: test.erl

package info (click to toggle)
erlang 1%3A17.3-dfsg-4
  • links: PTS, VCS
  • area: main
  • in suites: jessie-kfreebsd
  • size: 173,260 kB
  • sloc: erlang: 1,354,163; xml: 365,926; ansic: 325,705; cpp: 50,390; makefile: 23,663; java: 10,540; sh: 10,013; lisp: 8,056; python: 4,826; pascal: 3,263; asm: 2,904; perl: 2,853; tcl: 245; sed: 86
file content (25 lines) | stat: -rw-r--r-- 437 bytes parent folder | download | duplicates (17)
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
%%
%% This is a test file
%%

-module(test).

-export([nrev/1]).

%% Just a naive reverse function in order
%% to get a code example with some comments.

nrev([X | Xs]) ->
    append(X, nrev(Xs));  % Quadratic behaviour
nrev([]) ->
    %% The trivial case:
    [].

  %% We need `append' as a subroutine:

append(Y, [X | Xs]) ->
    [X | append(Y, Xs)];    % Simple, innit?
append(Y, []) ->
    [Y].    % Done.

%% ---- end of file ----