PICSimLab - Programmable IC Simulator Laboratory 0.9.2
PICSimLab - API
Loading...
Searching...
No Matches
virtual_VCD_Dump.h
1/* ########################################################################
2
3 PICSimLab - Programmable IC Simulator Laboratory
4
5 ########################################################################
6
7 Copyright (c) : 2010-2024 Luis Claudio GambĂ´a Lopes <lcgamboa@yahoo.com>
8
9 This program is free software; you can redistribute it and/or modify
10 it under the terms of the GNU General Public License as published by
11 the Free Software Foundation; either version 2, or (at your option)
12 any later version.
13
14 This program is distributed in the hope that it will be useful,
15 but WITHOUT ANY WARRANTY; without even the implied warranty of
16 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
17 GNU General Public License for more details.
18
19 You should have received a copy of the GNU General Public License
20 along with this program; if not, write to the Free Software
21 Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
22
23 For e-mail suggestions : lcgamboa@yahoo.com
24 ######################################################################## */
25
26#ifndef PART_VCD_DUMP_H
27#define PART_VCD_DUMP_H
28
29#include "../lib/part.h"
30
31#define PART_VCD_DUMP_Name "VCD Dump"
32
33class cpart_VCD_Dump : public part {
34public:
35 std::string GetAboutInfo(void) override { return "L.C. Gamboa \n <lcgamboa@yahoo.com>"; };
36 cpart_VCD_Dump(const unsigned x, const unsigned y, const char* name, const char* type, board* pboard_,
37 const int id_);
38 ~cpart_VCD_Dump(void);
39 void DrawOutput(const unsigned int index) override;
40 void PreProcess(void) override;
41 void Process(void) override;
42 void PostProcess(void) override;
43 void OnMouseButtonPress(unsigned int inputId, unsigned int button, unsigned int x, unsigned int y,
44 unsigned int state) override;
45 void ConfigurePropertiesWindow(void) override;
46 void ReadPropertiesWindow(void) override;
47 std::string WritePreferences(void) override;
48 void ReadPreferences(std::string value) override;
49 unsigned short GetInputId(char* name) override;
50 unsigned short GetOutputId(char* name) override;
51
52private:
53 void RegisterRemoteControl(void) override;
54 unsigned char input_pins[8];
55 unsigned char old_value_pins[8];
56 char f_vcd_name[200];
57 FILE* f_vcd;
58 unsigned long vcd_count;
59 unsigned char rec;
60};
61
62#endif /* PART_VCD_DUMP_H */
Board class.
Definition board.h:111
Definition virtual_VCD_Dump.h:33
void RegisterRemoteControl(void) override
Register remote control variables.
Definition virtual_VCD_Dump.cc:92
std::string WritePreferences(void) override
Called to save part preferences in configuration file.
Definition virtual_VCD_Dump.cc:233
unsigned short GetOutputId(char *name) override
return the output ids numbers of names used in output map
Definition virtual_VCD_Dump.cc:189
void OnMouseButtonPress(unsigned int inputId, unsigned int button, unsigned int x, unsigned int y, unsigned int state) override
Event handler on the part.
Definition virtual_VCD_Dump.cc:363
unsigned short GetInputId(char *name) override
return the input ids numbers of names used in input map
Definition virtual_VCD_Dump.cc:179
void Process(void) override
Called every CPU step.
Definition virtual_VCD_Dump.cc:329
void ConfigurePropertiesWindow(void) override
Called to configure the properties window.
Definition virtual_VCD_Dump.cc:247
void DrawOutput(const unsigned int index) override
Called to draw every output.
Definition virtual_VCD_Dump.cc:109
void PostProcess(void) override
Called every end of CPU process.
Definition virtual_VCD_Dump.cc:352
void PreProcess(void) override
Called every start of CPU process.
Definition virtual_VCD_Dump.cc:269
std::string GetAboutInfo(void) override
Return the about information of part.
Definition virtual_VCD_Dump.h:35
void ReadPreferences(std::string value) override
Called whe configuration file load preferences.
Definition virtual_VCD_Dump.cc:242
void ReadPropertiesWindow(void) override
Called when properties window close.
Definition virtual_VCD_Dump.cc:258
PART class.
Definition part.h:49