File: funascii.c

package info (click to toggle)
icmake 6.21-4
  • links: PTS
  • area: main
  • in suites: hamm, potato, slink
  • size: 1,964 kB
  • ctags: 1,053
  • sloc: ansic: 9,245; makefile: 1,139; sh: 141; asm: 126
file content (41 lines) | stat: -rw-r--r-- 901 bytes parent folder | download | duplicates (3)
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
/*
\fucref{fun\_ascii}{void fun\_ascii ()}
    {}
    {}
    {}
    {}
    {funstrel.c}
    {

        This function is called when a call to the built-in function {\em
        ascii} is to be processed.

        If the last pushed value is a string, then the return register
        is set to the integer (ASCII number) representation of the first
        character in the string. Otherwise, the stacked argument is taken
        as an {\em int} and the return register is set to the
        character-to-string representation.

    }
*/

#include "icm-exec.h"

void fun_ascii ()
{
    char
        buf [2];

    if (stack [sp].type == e_str)
    {
        reg.type = e_int;
        reg.vu.intval = * (stack [sp].vu.i->ls.str);
    }
    else
    {
        buf [1] = '\0';
        buf [0] = (char) stack [sp].vu.intval;
        reg = newvar (e_str);
        reg.vu.i->ls.str = xstrdup (buf);
    }
}