verilator/test_regress/t/t_queue_class.v
2024-09-02 09:45:47 -04:00

45 lines
910 B
Systemverilog

// DESCRIPTION: Verilator: Verilog Test module
//
// This file ONLY is placed under the Creative Commons Public Domain, for
// any use, without warranty, 2019 by Wilson Snyder.
// SPDX-License-Identifier: CC0-1.0
module t (/*AUTOARG*/);
class Cls;
int que[$];
task push_data(int val);
que.push_back(val);
endtask
function logic ok;
return '1;
endfunction
endclass
initial begin
Cls c2 [1:0];
Cls cq[$];
c2[0] = new();
c2[0].push_data(20); // Works
if (c2[0].que.size() != 1) $stop;
c2[0].que.push_back(10); // Unsupported
if (c2[0].que.size() != 2) $stop;
// Test there's no side effect warning on iteration
foreach (cq[i])
case (cq[i].ok())
'0: $stop;
'1: $stop;
endcase
$write("*-* All Finished *-*\n");
$finish;
end
endmodule