verilator/test_regress/t/t_class2.v

46 lines
1.1 KiB
Systemverilog
Raw Normal View History

// DESCRIPTION: Verilator: Verilog Test module
//
// This file ONLY is placed under the Creative Commons Public Domain, for
// any use, without warranty, 2020 by Wilson Snyder.
// SPDX-License-Identifier: CC0-1.0
package Pkg;
typedef enum { ENUMP_VAL = 33 } enump_t;
endpackage
module t (/*AUTOARG*/);
class Cls;
int imembera;
int imemberb;
typedef enum { ENUM_VAL = 22 } enum_t;
endclass : Cls
Cls c;
Cls d;
Cls::enum_t e;
initial begin
// Alternate between two versions to make sure we don't
// constant propagate between them.
c = new;
d = new;
e = Cls::ENUM_VAL;
c.imembera = 10;
d.imembera = 11;
c.imemberb = 20;
d.imemberb = 21;
if (c.imembera != 10) $stop;
if (d.imembera != 11) $stop;
if (c.imemberb != 20) $stop;
if (d.imemberb != 21) $stop;
if (Pkg::ENUMP_VAL != 33) $stop;
if (Cls::ENUM_VAL != 22) $stop;
if (c.ENUM_VAL != 22) $stop;
if (e != Cls::ENUM_VAL) $stop;
if (e != 22) $stop;
$write("*-* All Finished *-*\n");
$finish;
end
endmodule