Beispiel #1
0
promisedToAcceptNoEarlierThan = 0
lastAccepted = -1

while True:
    currMessage = messenger.getNextMessage()
    if currMessage['timePeriod'] <= lastAccepted: continue
    response = {'by': acceptorName, 'timePeriod': currMessage['timePeriod']}

    if currMessage['type'] == 'prepare':
        if currMessage['timePeriod'] > promisedToAcceptNoEarlierThan:
            promisedToAcceptNoEarlierThan = currMessage['timePeriod']

        response['type'] = 'promised'

        if lastAccepted >= 0:
            response['lastAcceptedTimePeriod'] = lastAccepted
            response['lastAcceptedValue'] = lastAcceptedValue
        else:
            response['haveAccepted'] = False

    elif currMessage['type'] == 'proposed':
        if currMessage['timePeriod'] < promisedToAcceptNoEarlierThan: continue

        lastAccepted = currMessage['timePeriod']
        lastAcceptedValue = currMessage['value']

        response['type'] = 'accepted'
        response['value'] = currMessage['value']

    messenger.postMessage(response)
Beispiel #2
0
promisedToAcceptNoEarlierThan = 0
lastAccepted = -1

while True:
  currMessage = messenger.getNextMessage()
  if currMessage['timePeriod'] <= lastAccepted: continue
  response = {'by':acceptorName, 'timePeriod':currMessage['timePeriod']}

  if currMessage['type'] == 'prepare':
    if currMessage['timePeriod'] > promisedToAcceptNoEarlierThan:
      promisedToAcceptNoEarlierThan = currMessage['timePeriod']
    
    response['type'] = 'promised'

    if lastAccepted >= 0:
      response['lastAcceptedTimePeriod'] = lastAccepted
      response['lastAcceptedValue']      = lastAcceptedValue
    else:
      response['haveAccepted']           = False

  elif currMessage['type'] == 'proposed':
    if currMessage['timePeriod'] < promisedToAcceptNoEarlierThan: continue

    lastAccepted = currMessage['timePeriod']
    lastAcceptedValue = currMessage['value']

    response['type'] = 'accepted'
    response['value'] = currMessage['value']

  messenger.postMessage(response)
Beispiel #3
0
from os        import getpid
from sys       import argv

freeValue = argv[1]
messenger = Messenger('http://127.0.0.1:24192/p/dt-py-' + str(getpid()).zfill(5))
received = []
latestProposedTimePeriod = 0

while True:
  currMessage = messenger.getNextMessage()
  if currMessage['timePeriod'] <= latestProposedTimePeriod: continue
  for prevMessage in received:
    if currMessage['timePeriod'] != prevMessage['timePeriod']: continue
    if currMessage['by'] == prevMessage['by']: continue

    proposedValue = freeValue

    currLATP = currMessage.get('lastAcceptedTimePeriod', -1)
    prevLATP = prevMessage.get('lastAcceptedTimePeriod', -1)

    if currLATP > 0:
      proposedValue = currMessage['lastAcceptedValue']

    if prevLATP > 0 and prevLATP > currLATP:
      proposedValue = currMessage['lastAcceptedValue']

    messenger.postMessage({'type':'proposed','timePeriod':currMessage['timePeriod'], 'value':proposedValue})
    break

  received.append(currMessage)