86 lines
		
	
	
		
			3.0 KiB
		
	
	
	
		
			Python
		
	
	
			
		
		
	
	
			86 lines
		
	
	
		
			3.0 KiB
		
	
	
	
		
			Python
		
	
	
| # push.py
 | |
| #
 | |
| # Copyright 2007 by David Delbecq
 | |
| #
 | |
| # This program is free software; you can redistribute it and/or modify
 | |
| # it under the terms of the GNU General Public License as published by
 | |
| # the Free Software Foundation; either version 2 of the License, or
 | |
| # (at your option) any later version.
 | |
| #
 | |
| # This program is distributed in the hope that it will be useful,
 | |
| # but WITHOUT ANY WARRANTY; without even the implied warranty of
 | |
| # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 | |
| # GNU General Public License for more details.
 | |
| #
 | |
| # You should have received a copy of the GNU General Public License
 | |
| # along with this program; if not, write to the Free Software
 | |
| # Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
 | |
| #
 | |
| #
 | |
| #
 | |
| # This script make the event it is attached to (not global!)
 | |
| # trigger a connected value at specific moment of year/day.
 | |
| # It will behave as if a button was "pushed" when entering period
 | |
| # and "release" after the period. Typical use is to use it as
 | |
| # event_time on a living object (that objects that triggers
 | |
| # time events).
 | |
| # This script ensure button remains pushed for all period, and
 | |
| # get release after period. This works even is map is loaded
 | |
| # in middle of period or map gets released from memory and put in
 | |
| # cache. In those case, event will just ensure that "current" state
 | |
| # correspond to expected state and correct status if needed.
 | |
| # Note: the event must be inside an object
 | |
| # which can find a path, using inventory, to a toplavel
 | |
| # object that is on a Map.
 | |
| #
 | |
| # exemple, to make an "push" starting at Morning and ending after Noon:
 | |
| #
 | |
| # arch event_time
 | |
| # title Python
 | |
| # slaying /python/tod/push.py
 | |
| # msg
 | |
| # {
 | |
| # "connected":"69",
 | |
| # "when":["Morning","Noon"],
 | |
| # "match":"one"
 | |
| # }
 | |
| # endmsg
 | |
| # end
 | |
| # parameters are separated by comas. First one
 | |
| # is connected value to trigger, other ones are
 | |
| # one or more periods where state must become "pushed"
 | |
| import Crossfire
 | |
| import string
 | |
| from CFTimeOfDay import TimeOfDay
 | |
| import cjson
 | |
| event = Crossfire.WhatIsEvent()
 | |
| parameters = cjson.decode(event.Message)
 | |
| alreadymatched = (event.Value!=0)
 | |
| connected = int(parameters["connected"])
 | |
| inverse = "inverse" in parameters and parameters["inverse"] == True
 | |
| match = False
 | |
| if not "match" in parameters:
 | |
|     Crossfire.Log(Crossfire.LogError,"Script push_period.py didn't get a 'match' parameter. Only got %s" %parameters)
 | |
| elif parameters["match"].lower() == "one":
 | |
|     match=TimeOfDay().matchAny(parameters["when"]) != inverse
 | |
| elif parameters["match"].lower() == "all":
 | |
|     match=TimeOfDay().matchAll(parameters["when"]) != inverse
 | |
| else:
 | |
|     Crossfire.Log(Crossfire.LogError,"Script push_period.py didn't get a 'match' parameter. Only got %s" %parameters)
 | |
| 
 | |
| #pushdown if need
 | |
| if (match & (not alreadymatched)):
 | |
|     op = event
 | |
|     while (op.Env):
 | |
|         op=op.Env
 | |
|     map = op.Map
 | |
|     map.TriggerConnected(connected,1,Crossfire.WhoAmI())
 | |
|     event.Value=1
 | |
| if ( (not match) & alreadymatched):
 | |
|     op = event
 | |
|     while (op.Env):
 | |
|         op=op.Env
 | |
|     map = op.Map
 | |
|     map.TriggerConnected(connected,0,Crossfire.WhoAmI())
 | |
|     event.Value=0
 |