File: compound.cc

package info (click to toggle)
icmake 13.05.01-1
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid
  • size: 7,132 kB
  • sloc: cpp: 11,595; fortran: 883; makefile: 853; sh: 546; pascal: 342
file content (22 lines) | stat: -rw-r--r-- 625 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
#define XERR
#include "semval.ih"

    // lhs @= rhs becomes: 
    //      push lhs, push rhs, @, copy lhs (-> pop lhs if it's the last
    //                                          step of the expression)
SemVal SemVal::compound(Opcode::Byte opcode, SemVal &&rhs)
{
    if (not assignable(opcode, rhs))
        return move(*this);

        // a (compound) assignment is always handled by code:
        // lhs code | rhs code | operation | copy_var to lhs
    push();
    rhs.push();

    *this << rhs << opcode << Opcode::copy_var << as<short>(d_value);

    d_type = (d_type & e_mask) | e_var;

    return move(*this);
}