PICSimLab - Programmable IC Simulator Laboratory 0.9.2
PICSimLab - API
Loading...
Searching...
No Matches
virtual_VCD_Dump_Mem.h
1/* ########################################################################
2
3 PICSimLab - Programmable IC Simulator Laboratory
4
5 ########################################################################
6
7 Copyright (c) : 2024-2025 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_MEM_H
27#define PART_VCD_DUMP_MEM_H
28
29#include "../lib/part.h"
30
31#define PART_VCD_DUMP_MEM_Name "VCD Dump Memory"
32
33class cpart_VCD_Dump_Mem : public part {
34public:
35 std::string GetAboutInfo(void) override { return "L.C. Gamboa \n <lcgamboa@yahoo.com>"; };
36 cpart_VCD_Dump_Mem(const unsigned x, const unsigned y, const char* name, const char* type, board* pboard_,
37 const int id_);
39 void DrawOutput(const unsigned int index) override;
40 void PreProcess(void) override;
41 void Process(void) override;
42 std::string GetPictureFileName(void) override { return "VCD Dump/part.svg"; };
43 std::string GetMapFile(void) override { return "VCD Dump/part.map"; };
44 void PostProcess(void) override;
45 void OnMouseButtonPress(unsigned int inputId, unsigned int button, unsigned int x, unsigned int y,
46 unsigned int state) override;
47 void ConfigurePropertiesWindow(void) override;
48 void ReadPropertiesWindow(void) override;
49 std::string WritePreferences(void) override;
50 void ReadPreferences(std::string value) override;
51 unsigned short GetInputId(char* name) override;
52 unsigned short GetOutputId(char* name) override;
53
54private:
55 void RegisterRemoteControl(void) override;
56
57 unsigned long output_bits_alm[8];
58 unsigned char output_bits[8];
59 long mcount;
60 int JUMPSTEPS_;
61 char f_vcd_name[200];
62 FILE* f_vcd;
63 unsigned long vcd_count;
64 unsigned char rec;
65 unsigned char mem_size;
66 unsigned short mem_addr;
67 unsigned short* mem_ptr;
68 unsigned short mem_old;
69};
70
71#endif /* PART_VCD_DUMP_MEM_H */
Board class.
Definition board.h:114
Definition virtual_VCD_Dump_Mem.h:33
std::string GetAboutInfo(void) override
Return the about information of part.
Definition virtual_VCD_Dump_Mem.h:35
std::string GetPictureFileName(void) override
Return the filename of part picture.
Definition virtual_VCD_Dump_Mem.h:42
std::string WritePreferences(void) override
Called to save part preferences in configuration file.
Definition virtual_VCD_Dump_Mem.cc:211
void ReadPreferences(std::string value) override
Called whe configuration file load preferences.
Definition virtual_VCD_Dump_Mem.cc:217
void Process(void) override
Called every CPU step.
Definition virtual_VCD_Dump_Mem.cc:321
std::string GetMapFile(void) override
Return the filename of part picture map.
Definition virtual_VCD_Dump_Mem.h:43
void ReadPropertiesWindow(void) override
Called when properties window close.
Definition virtual_VCD_Dump_Mem.cc:234
void PreProcess(void) override
Called every start of CPU process.
Definition virtual_VCD_Dump_Mem.cc:244
void RegisterRemoteControl(void) override
Register remote control variables.
Definition virtual_VCD_Dump_Mem.cc:87
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_Mem.cc:395
unsigned short GetInputId(char *name) override
return the input ids numbers of names used in input map
Definition virtual_VCD_Dump_Mem.cc:157
unsigned short GetOutputId(char *name) override
return the output ids numbers of names used in output map
Definition virtual_VCD_Dump_Mem.cc:167
void PostProcess(void) override
Called every end of CPU process.
Definition virtual_VCD_Dump_Mem.cc:375
void ConfigurePropertiesWindow(void) override
Called to configure the properties window.
Definition virtual_VCD_Dump_Mem.cc:225
void DrawOutput(const unsigned int index) override
Called to draw every output.
Definition virtual_VCD_Dump_Mem.cc:104
PART class.
Definition part.h:49