File indexing completed on 2024-09-08 05:08:55

0001 /***************************************************************************
0002  *   Copyright (C) 2003-2005 by David Saxton                               *
0003  *   david@bluehaze.org                                                    *
0004  *                                                                         *
0005  *   This program is free software; you can redistribute it and/or modify  *
0006  *   it under the terms of the GNU General Public License as published by  *
0007  *   the Free Software Foundation; either version 2 of the License, or     *
0008  *   (at your option) any later version.                                   *
0009  ***************************************************************************/
0010 
0011 #ifndef CIRCUITDOCUMENT_H
0012 #define CIRCUITDOCUMENT_H
0013 
0014 #include "circuiticndocument.h"
0015 #include "pin.h"
0016 
0017 class Circuit;
0018 class Component;
0019 class Connector;
0020 class ECNode;
0021 class Element;
0022 class CircuitICNDocument;
0023 class KTechlab;
0024 class Pin;
0025 class QTimer;
0026 class Switch;
0027 class Wire;
0028 
0029 class KActionMenu;
0030 
0031 typedef QList<Circuit *> CircuitList;
0032 typedef QList<Component *> ComponentList;
0033 typedef QList<QPointer<Connector>> ConnectorList;
0034 typedef QList<ECNode *> ECNodeList;
0035 typedef QList<Element *> ElementList;
0036 typedef QList<QPointer<Pin>> PinList;
0037 typedef QList<Switch *> SwitchList;
0038 typedef QList<QPointer<Wire>> WireList;
0039 
0040 class Circuitoid
0041 {
0042 public:
0043     bool contains(Pin *node)
0044     {
0045         return pinList.contains(node);
0046     }
0047     bool contains(Element *ele)
0048     {
0049         return elementList.contains(ele);
0050     }
0051 
0052     void addPin(Pin *node)
0053     {
0054         if (node && !contains(node))
0055             pinList += node;
0056     }
0057     void addElement(Element *ele)
0058     {
0059         if (ele && !contains(ele))
0060             elementList += ele;
0061     }
0062 
0063     PinList pinList;
0064     ElementList elementList;
0065 };
0066 
0067 /**
0068 CircuitDocument handles allocation of the components displayed in the ICNDocument
0069 to various Circuits, where the simulation can be performed, and displays the
0070 information from those simulations back on the ICNDocument
0071 @short Circuit view
0072 @author David Saxton
0073 */
0074 class CircuitDocument : public CircuitICNDocument
0075 {
0076     Q_OBJECT
0077 public:
0078     CircuitDocument(const QString &caption);
0079     ~CircuitDocument() override;
0080 
0081     View *createView(ViewContainer *viewContainer, uint viewAreaId) override;
0082 
0083     void calculateConnectorCurrents();
0084     /**
0085      * Count the number of ExternalConnection components in the CNItemList
0086      */
0087     int countExtCon(const ItemList &cnItemList) const;
0088 
0089     void update() override;
0090 
0091 public slots:
0092     /**
0093      * Creates a subcircuit from the currently selected components
0094      */
0095     void createSubcircuit();
0096     void displayEquations();
0097     void setOrientation0();
0098     void setOrientation90();
0099     void setOrientation180();
0100     void setOrientation270();
0101     void rotateCounterClockwise();
0102     void rotateClockwise();
0103     void flipHorizontally();
0104     void flipVertically();
0105     /**
0106      * Enables / disables / selects various actions depending on what is
0107      * selected or not.
0108      */
0109     void slotInitItemActions() override;
0110     void requestAssignCircuits();
0111     void componentAdded(Item *item);
0112     void componentRemoved(Item *item);
0113     void connectorAddedSlot(Connector *connector);
0114     void slotUpdateConfiguration() override;
0115 
0116 protected:
0117     void itemAdded(Item *item) override;
0118     void fillContextMenu(const QPoint &pos) override;
0119     bool isValidItem(Item *item) override;
0120     bool isValidItem(const QString &itemId) override;
0121 
0122     KActionMenu *m_pOrientationAction;
0123 
0124 private slots:
0125     void assignCircuits();
0126 
0127 private:
0128     /**
0129      * If the given circuitoid can be a LogicCircuit, then it will be added to
0130      * m_logicCircuits, and return true. Else returns false.
0131      */
0132     bool tryAsLogicCircuit(Circuitoid *circuitoid);
0133     /**
0134      * Creates a circuit from the circuitoid
0135      */
0136     Circuit *createCircuit(Circuitoid *circuitoid);
0137 
0138     /**
0139      * @param pin Current node (will be added, then tested for further
0140      * connections).
0141      * @param pinList List of nodes in current partition.
0142      * @param unassignedPins The pool of all nodes in the CircuitDocument
0143      * waiting for assignment.
0144      * @param onlyGroundDependent if true, then the partition will not use
0145      * circuit-dependent pins to include new pins while growing the
0146      * partition.
0147      */
0148     void getPartition(Pin *pin, PinList *pinList, PinList *unassignedPins, bool onlyGroundDependent = false);
0149     /**
0150      * Takes the nodeList (generated by getPartition), splits it at ground nodes,
0151      * and creates circuits from each split.
0152      */
0153     void splitIntoCircuits(PinList *pinList);
0154     /**
0155      * Construct a circuit from the given node, stopping at the groundnodes
0156      */
0157     void recursivePinAdd(Pin *pin, Circuitoid *circuitoid, PinList *unassignedPins);
0158 
0159     void deleteCircuits();
0160 
0161     QTimer *m_updateCircuitsTmr;
0162     CircuitList m_circuitList;
0163     ComponentList m_toSimulateList;
0164     ComponentList m_componentList; // List is built up during call to assignCircuits
0165 
0166     // hmm, we have one of these in circuit too....
0167     PinList m_pinList;
0168     WireList m_wireList;
0169     SwitchList m_switchList;
0170 };
0171 
0172 #endif