I can't imagine which script would be causing that issue. I have (and wrote) all those scripts except for SimpleDoorControls.js, and I don't get an infinite loop error with them. I'd suggest disabling that one and seeing if you get the issue.
I have pasted the entire script here, which, honestly, I know nothing about. All of my experience with these scripts and macros is taking things I've found on the forums and changing just enough of them to make it roll the dice we need without breaking the thing.
/*
SimpleDoorControls
Use
Creating a linked door system
-----------------------------
Verify you're on the Token/Object Layer.
Place a graphic of a door or other barrier in the closed position.
Name that token DoorClosed (all one word, and yes the D and C need to be capitalized).
Place a graphic of a door in the desired open position.
Name that token DoorOpen (all one word, and yes the D and O need to be capitalized).
Draw a line to act as the Dynamic Lighting barrier for the door when closed (while still on the Token layer).
Select all three objects.
Type !DoorsLink (or set it as a macro and use that macro)
The Open Door and Dynamic Lighting barrier will be moved to the GM layer and Dynamic Lighting layer, respectively.
The open and closed doors will be renamed. This is how they are linked.
DO NOT RENAME THE LINKED OBJECTS.
Do this for each set of doors needed.
Opening and Closing doors
-------------------------
Once the objects are linked
Select the door on the token layer
Type !DoorOpenClose
The door will open if it is closed, or it will close if it is opened.
*/
on("chat:message", function (msg) {
"use strict";
var Parts = {};
if (msg.type !== "api") {
return;
}
switch(msg.content.split(/\s+/).shift()) {
case "!DoorsLink":
//make sure three items are selected
if (msg.selected.length > 3) {
sendChat("Doors", "/w gm You have selected too many things, looking among them for what I need.");
} else if (msg.selected.length < 3) {
sendChat("Doors", "/w gm You have not selected enough things.");
break;
}
//identify and get the ID for each each type of selected item
_.each(msg.selected, function(obj) {
var o = getObj(obj._type, obj._id);
if(o) {
if (o.get("_type") === "graphic" && o.get("name") === "DoorOpen" && !Parts.DoorOpen) {
Parts.DoorOpen=o;
} else if (o.get("type") === "graphic" && o.get("name") === "DoorClosed" && !Parts.DoorClosed) {
Parts.DoorClosed = o;
} else if (o.get("type") === "path" && !Parts.Path) {
Parts.Path = o;
}
}
});
if( Parts.DoorOpen && Parts.DoorClosed && Parts.Path) {
Parts.DoorOpen.set({
name: Parts.Path.id +" "+Parts.DoorClosed.id,
layer: "gmlayer"
});
Parts.DoorClosed.set({
name: Parts.Path.id +" "+Parts.DoorOpen.id
});
Parts.Path.set({
layer: "walls"
});
} else {
sendChat("Doors", "/w GM Couldn't fine required piece:<ul>"
+(Parts.DoorOpen ? '' : '<li>Token named "DoorOpen".</li>')
+(Parts.DoorClosed ? '' : '<li>Token named "DoorClosed".</li>')
+(Parts.Path ? '' : '<li>Path for Dynamic Light Layer.</li>')
+'</ul>'
);
}
break;
case "!DoorOpenClose":
_.chain(msg.selected)
.map(function(o){
return getObj('graphic', o._id);
})
.reject(_.isUndefined)
.filter(function(o){
return 'objects' === o.get('layer');
})
.each(function(o){
var params=o.get('name').split(/\s+/),
oDoor = getObj('graphic',params[1]),
oPath = getObj('path',params[0]);
if(oDoor && oPath) {
o.set({
layer: 'gmlayer'
});
oDoor.set({
layer: 'objects'
});
oPath.set({
layer: ( 'walls' === oPath.get('layer') ? 'gmlayer' : 'walls')
});
} else {
sendChat('Doors','/w gm Missing components: <ul>'
+(oDoor ? '' : '<li>GM Layer Door</li>')
+(oPath ? '' : '<li>Dynamic Lighting Path</li>')
+'</ul>');
}
});
break;
}
});
I've had them occasionally for about 6 months I'd say. I notice that it has happened when I am using my macros for TokenMod and they stop working.
TokenMod I use every day in every game I run for the last year or so.
Message of the Day obviously just sits there doing it's thing every day. Had that for about a year.
SimpleDoorControls I haven't made hardly any use of, but I've had it for about 6 months or so.
Search was a new pick up last month and I don't think we've gotten much use out of it. I got it for my players mostly.
TokenNameNumber is a new pick up last month too, and I've only just started using it this week in earnest.
I"m also using VTT Enhancement Suite, not sure if that is related or not.
https://chrome.google.com/webstore/detail/vtt-enhancement-suite/fadcomaehamhdhekodcpiglabcjkepff
That extension won't have any bearing on the API.
Has it always been 3-5x per hour, or is that a recent development?
That's a good question, I'm noticing it this week since I have been overhauling my monster manual in preparation for making a campaign to transfer all of my monsters into for storage and transmog from one spot in the future.
Since I'm spending a lot of time in and out of the tokens and monster sheets, I'm using my tokenmod controls constantly to set the token parameters and I notice almost immediately when the API shuts down, so I'm restarting it manually right away. So it could be that I'm just now noticing how often it is because of how often I am starting it up right now.
Possibly worth noting - while I had been working all week on my Rise of Tiamat campaign, today I am working on my Storm King's Thunder campaign, and I'm having the same issue, with the same API scripts installed.
Does it only seem to happen when you use TokenMod commands? Can you narrow it down to a few commands that seem to cause it? Maybe post them here?
I couldn't say it only seems to happen for TokenMod commands, but those are the ones that are actively used, so I notice when they fail. These are the 2 macros I'm using most often. The first one I have used a ton in the past two days, when I've noticed this issue constantly.
I create monsters by dragging them from the SRD or from scratch if need be. Then I upload my token .PNG directly into the NPC sheet and save it. Drag the token out of the journal onto the table top, select it and press this macro:
!token-mod --set bar1_link|hp !token-mod --set bar1_reset| !token-mod --set bar2_link|npc_ac !token-mod --set bar1_link| !token-mod --off light_hassight !token-mod --set light_radius|=0 light_dimradius|0 !token-mod --off light_otherplayers !token-mod --on showname !token-mod --on showplayers_name !token-mod --set defaulttoken
This makes tokens "dead". I often notice that the API has crashed during a game session when I try to use this macro and it fails.
!token-mod --set statusmarkers|=dead
!token-mod --off showname
!token-mod --set bar1|0
Try specifying those all as a single command. By having that as 10 separate commands, it puts a ton of load on the event system. You can span multiple lines with {{ }} to keep the formatting nice.
OK I understand what you're saying, but I can't seem to nail down the syntax. Can you give me an example?
Your top command would look like
!token-mod {{ --set bar1_link|hp bar1_reset| bar2_link|npc_ac bar1_link| --off light_hassight --set light_radius|=0 light_dimradius|0 --off light_otherplayers --on showname showplayers_name --set defaulttoken }}
You can probably shift them around a bit too for neatness, getting all the sets together and all the offs together.
I'm curious about this line
--set light_radius|=0 light_dimradius|0
I dont use dynamic lighting, so I dont use these commands. Is there a difference between |=0 for light_radius, and |0 for dimradius?
That's part of TokenMod. = is the default operation if one isn't specified. You only really need to specify it when you want to explicitly assign a negative value:
!token-mod --set light_radius|=-5
!token-mod --set light_radius|-5
The first sets the light_radius to -5, the second deducts 5 from the current value and sets it to the resultant value.
Wow, OK, this may have resolved my Infinite Loop issue. I haven't had it happen since yesterday morning I think.
I am having an issue where the macro isn't setting the hit points. After clicking the macro all of the other operations have completed, but Bar 1 is set to NONE and there are no values at all in the Bar 1 boxes.
!token-mod {{ --set bar1_link|hp bar1_reset| bar2_link|npc_ac bar1_link| --off light_hassight --set light_radius|=0 light_dimradius|0 --off light_otherplayers --on showname showplayers_name showplayers_bar1 --set defaulttoken }}
swap the order of bar1_reset is after bar1_link|hp, and after that you have bar1_link|
I know thats the order i gave earlier, but i was just copying your earlier commands. So it should probably be
!token-mod {{ --set bar1_reset| bar1_link|hpbar2_link|npc_ac
--off light_hassight --set light_radius|=0 light_dimradius|0 --off light_otherplayers --on showname showplayers_name showplayers_bar1 --set defaulttoken }}
Maybe bar1_reset isnt needed? Or maybe you should have a bar2_reset there too (before its link).
Maybe Aaron can confirm/deny, but this is my understanding of these commands:
bar1_link|hp bar1_reset| bar2_link|npc_ac bar1_link|
In this example, let assume the character sheet has 60 hp.
1) Bar 1 is linked to HP, and the result is 0/60.
2) Bar 1 is reset to maximum value, and the result is 60/60
3) Bar 2 is linked to the NPC_AC value (this is working fine)
4) Bar 1 is UNlinked to any value (the purpose in this case is make this token a mook - ie it's a goblin and I'm going to need more than 1 linked to this sheet.
1) will set link it to HP and set the value to @{hp}/@{hp|max}.
2) will set bar1_current to bar1_max.
You should’ve need 2) in this case. It is failing because all the changes are applied as one set operation for efficiency, so the state of bar1_max is read from the beginning state of the token, not the state after the link operation. I can probably fix it to look at the updated state if you find it isn’t right without it.
So.. this version is working, but only if I press it twice. The first press ignores the bar1_reset| command, or at least, it doesn't set it to max value of the character sheet's hp.
I'm really just trial-and-error mashing these commands together, with no sense of what is going to happen until I try it.
!token-mod {{ --set bar1_link|hp bar1_reset| light_radius|=0 light_dimradius|0 bar2_link|npc_ac --off light_hassight light_otherplayers --on showname showplayers_name showplayers_bar1 }} !token-mod {{ --set bar1_link| defaulttoken }}