diff options
Diffstat (limited to 'src/converter/schematic_converters/lib/PythonLib/wire.py')
-rw-r--r-- | src/converter/schematic_converters/lib/PythonLib/wire.py | 66 |
1 files changed, 66 insertions, 0 deletions
diff --git a/src/converter/schematic_converters/lib/PythonLib/wire.py b/src/converter/schematic_converters/lib/PythonLib/wire.py new file mode 100644 index 00000000..b8f56037 --- /dev/null +++ b/src/converter/schematic_converters/lib/PythonLib/wire.py @@ -0,0 +1,66 @@ +#The MIT License (MIT) + +#PSpice to Oscad Schematic Converter +#This code is written by Suryavamshi Tenneti, FOSSEE, IIT Bombay +#The code is modified by Sumanto Kar and Gloria Nandihal, FOSSEE, IIT Bombay + + +from header import * + +class Wire: + x1 = 0 + y1 = 0 + x2 = 0 + y2 = 0 + def __init__(self, x1 = 0, y1 = 0, x2 = 0, y2 = 0): + self.x1 = x1 + self.x2 = x2 + self.y1 = y1 + self.y2 = y2 # print + + def print(self, output_stream): + output_stream.write('Wire Wire Line\n'+'\t') + output_stream.write(str(self.x1)+' '+str(self.y1)+' '+str(self.x2)+' ' +str(self.y2)+'\n') + +class Connector: + x = 0 + y = 0 + + def __init__(self, x = 0, y = 0): + self.x = x + self.y = y # print funciton of Connector class to print connectors format to output schematic file as per KiCad format + + def print(self, output_stream): + output_stream.write('Connection ~ '+str(self.x)+' '+str(self.y)+'\n')# Function parseWire to get the postion of wires + +def parseWire(input_stream, wires): + + line = input_stream.readline().strip() + while(line[0]!='@'): #print('parsing wire', line) + #print('parsing wire', line) + if line[0] == 's': #reading 's' + #print('Yes') + string = line + t,x1,y1,x2,y2 = string.split()[:-1] # retriving the values from string stream + x1 = int(x1) + y1 = int(y1) + x2 = int(x2) + y2 = int(y2) + + w = Wire(x1*MULT, y1*MULT, x2*MULT, y2*MULT) + wires.append(w) + line = input_stream.readline().strip() # Function parseConn to get the position of junction + return input_stream + +def parseConn(input_stream, conns): + line = input_stream.readline().strip() + while(line[0]!= '@'): + if line[0] == 'j': #reading 'j' + string = line + t,x1,y1 = string.split() + x1 = int(x1) + y1 = int(y1) + c = Connector(x1*MULT, y1*MULT) + conns.append(c) + line = input_stream.readline().strip() + return input_stream |