File: funstrel.c

package info (click to toggle)
icmake 6.22-2
  • links: PTS
  • area: main
  • in suites: woody
  • size: 2,120 kB
  • ctags: 1,045
  • sloc: ansic: 9,241; makefile: 1,138; asm: 126; sh: 124
file content (45 lines) | stat: -rw-r--r-- 1,003 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
42
43
44
45
/*
\fucref{fun\_str\_el}{void fun\_str\_el ()}
    {}
    {}
    {}
    {}
    {funstrel.c}
    {

        This function is called when an {\em op\_str\_el} opcode is enountered.
        The last pushed value is interpreted as a string, the one but last
        pushed value as an index.

        The return register {\em reg} is set to an {\em e\_str} variable:
        the character from the string at index {\em index}, terminated by
        $\backslash$0. If index is smaller than 0 or larger than the size of
        the string, {\em reg} holds a null-character.

    }
*/

#include "icm-exec.h"

void fun_str_el ()
{
    register int
        index;
    register char
        *str;
    char
        buf [2];

    reg = newvar (e_str);
    buf [1] = '\0';

    index = (unsigned) stack [sp].vu.intval;
    str   = stack [sp - 1].vu.i->ls.str;

    if (index < 0 || index >= (int) strlen (str))
        buf [0] = '\0';
    else
        buf [0] = str [index];

    reg.vu.i->ls.str = xstrdup (buf);
}