// 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 class ClsNoArg; const int imembera; // Ok for new() to assign to a const function new(); int other = other_func(); imembera = 5; if (other != 6) $stop; endfunction : new function int other_func(); return 6; endfunction endclass class ClsArg; int imembera; function new(int i); imembera = i + 1; endfunction function int geta; return imembera; endfunction static function ClsArg create6; ClsArg obj; obj = new(6 - 1); return obj; endfunction endclass class Cls2Arg; int imembera; int imemberb; function new(int i, int j); imembera = i + 1; imemberb = j + 2; endfunction function Cls2Arg clone(); Cls2Arg ret; ret = new(imembera, imemberb); return ret; endfunction endclass module t (/*AUTOARG*/); initial begin ClsNoArg c1; ClsArg c2; Cls2Arg c3; Cls2Arg c4; c1 = new; if (c1.imembera != 5) $stop; c2 = new(3 - 1); if (c2.imembera != 3) $stop; if (c2.geta() != 3) $stop; c2 = ClsArg::create6(); if (c2.imembera != 6) $stop; if (c2.geta() != 6) $stop; c3 = new(4, 5); if (c3.imembera != 5) $stop; if (c3.imemberb != 7) $stop; c4 = c3.clone(); if (c4.imembera != 6) $stop; if (c4.imemberb != 9) $stop; $write("*-* All Finished *-*\n"); $finish; end endmodule