// DESCRIPTION: Verilator: Verilog Test module for SystemVerilog 'alias' // // Simple bi-directional alias test. // // 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 typedef class paramed_class_t; typedef class arg_class_t; typedef paramed_class_t#(logic[3:0], 1) paramed_class_logic4_t; virtual class vclass #(type CTYPE_t = arg_class_t, int I = 0); pure virtual function void funcname(paramed_class_t #(CTYPE_t) v); endclass class paramed_class_t #(type TYPE, int I = 0); TYPE memb; endclass class arg_class_t; int ifield; endclass module t (/*AUTOARG*/); vclass vir; paramed_class_t#(arg_class_t) argu; initial begin argu = new; argu.memb = new; argu.memb.ifield = 1234; // vir.funcname(argu); if (argu.memb.ifield != 1234) $stop; $write("*-* All Finished *-*\n"); $finish; end endmodule