This is the HLP group project for team 5. The code is made to act as the GUI library for the Issie application. Issie is an "Interactive Schematic Simulator with Integrated", for more information about issie see the Issie Repo . The aim is to be able to replace the currently used drawing library.
The code allows you to add a different range (note that for demo purpose alt-n
creates new symbol of random type) of component symbol displayed on the canvas and connect them together using the wires. The code is set up three modules sheet
, buswire
, and symbol
where they are complied as symbol -> buswire-> sheet
, i.e. sheet acts as the perent module.
The symbol element creation is handled by the symbol.fs while the wire creation is handled by buswire.fs. The sheet module written in sheet.fs is used for the overall control of the system with function such as copy, past, drag, and select etc.
The code is setup so that the some symbols are generated on intialisation which can then be used to test all the different features.
The code which handles the initalisation in the code are the init
dummy functions in symbol
and buswire
. For production these function would most likely not contain the intialization of any symbols or wires.
- In the root directory, open up the command prompt
- Run the following code
- Windows:
build
- Linux:
build.sh
- Windows:
- If the program fails to run, go to the original skeleton code, retrieve the file
build.fsx
, and paste it into the root directory, then repeat step 2 again.
- In the root directory, open up the command prompt
- Run the following code
npm run dev
<root>
|- src // Contains the source code of the project
\- docs // Contains the documents explaining the layout of the code.
|- buswire.md
|- common_types.md
|- notes.md
|- sheet.md
|- issie_interface.md
|- feature_summary.md
\- symbol.md
All interfaces used in the project are defined in their respective \<module>.md
files found in docs/. There are also two other files, common_types.md and notes.md. common_types.md contains all the new type definitions we had to agree on, and notes.md contains notes on our design decisions. There is also a file named issie_interface.md which contains information about the function which exsist in the code for potential interface with issie.
For an exhaustive list of features, refer to feature_summary.md.
This was the inital allocation used under the individual phase. In the group phase the division has become less rigid as everyone has worked together to put all the modules together.
- Chizu
- Marcus
- Wei Loon
- Sofia
- Ole
- Ben