class documentation

This is a factory which produces protocols.

By default, buildProtocol will create a protocol of the class given in self.protocol.

Class Method forProtocol Create a factory for the given protocol.
Method buildProtocol Create an instance of a subclass of Protocol.
Method doStart Make sure startFactory is called.
Method doStop Make sure stopFactory is called.
Method logPrefix Describe this factory for log messages.
Method startFactory This will be called before I begin listening on a Port or Connector.
Method stopFactory This will be called before I stop listening on all Ports/Connectors.
Class Variable noisy Undocumented
Class Variable protocol Undocumented
Instance Variable numPorts Undocumented
@classmethod
def forProtocol(cls, protocol, *args, **kwargs): (source)

Create a factory for the given protocol.

It sets the protocol attribute and returns the constructed factory instance.

Parameters
protocolA Protocol subclass
*argsPositional arguments for the factory.
**kwargsKeyword arguments for the factory.
Returns
A Factory instance wired up to protocol.
def buildProtocol(self, addr: IAddress) -> Optional[Protocol]: (source)

Create an instance of a subclass of Protocol.

The returned instance will handle input on an incoming server connection, and an attribute "factory" pointing to the creating factory.

Alternatively, None may be returned to immediately close the new connection.

Override this method to alter how Protocol instances get created.

Parameters
addr:IAddressan object implementing IAddress
Returns
Optional[Protocol]Undocumented
def doStart(self): (source)

Make sure startFactory is called.

Users should not call this function themselves!

def doStop(self): (source)

Make sure stopFactory is called.

Users should not call this function themselves!

def logPrefix(self): (source)

Describe this factory for log messages.

def startFactory(self): (source)

This will be called before I begin listening on a Port or Connector.

It will only be called once, even if the factory is connected to multiple ports.

This can be used to perform 'unserialization' tasks that are best put off until things are actually running, such as connecting to a database, opening files, etcetera.

def stopFactory(self): (source)

This will be called before I stop listening on all Ports/Connectors.

This can be overridden to perform 'shutdown' tasks such as disconnecting database connections, closing files, etc.

It will be called, for example, before an application shuts down, if it was connected to a port. User code should not call this function directly.

numPorts = (source)

Undocumented