-
Notifications
You must be signed in to change notification settings - Fork 334
E2: Find Functions
This articles covers how to find entities in the world using E2's find functions.
To prevent players from crashing or lagging servers, E2 limits the rate you can perform find queries with.
These queries are any find functions that return one or more entities, including the findPlayerBy
functions.
By default, the rate limit is 20 per second with a burst limit of up to 10 per tick.
If you exceed either, your find results will come back empty until you're under the limit again!
findCanQuery()
will return if you can currently query at least once, and findCount()
will tell you how many queries you have left.
findMax()
and findUpdateRate()
will get you the burst limit and regeneration interval (time in seconds to regenerate by one) respectively.
Pretty much all remaining find functions can be divided into 4 groups and only work correctly when used in order:
- If applicable, define your find filters.
- Make one query
- If you want, clip the results and/or
sortByDistance
(and you can do this as often as you want!) - Retrieve the results (else it was all for nothing, right?)
- You may now go back to any previous point and continue again from there. Black/whitelist and last results are stored until you change them again (or reset the E2).
These are what I always see people (including myself) get wrong the most often. And I don't blame them either, the find blacklist & whitelist are rather poorly documented in the e2helper.
-
findInclude
functions add stuff to the whitelist -
findDisallow
functions block things that would otherwise pass due to the whitelist -
findExclude
functions add stuff to the blacklist -
findAllow
functions allow things that would otherwise be blocked by the blacklist
These "prefixes" can be combined with the following filter types for a wide variety of use-cases:
Filter | Input | Info |
---|---|---|
class |
string | Uses Lua patterns, see note below |
model |
string | Uses Lua patterns, see note below |
entity |
entity | |
entities |
array (of entities) | same list as Entity |
playerProps |
entity (player) | props owned by that player |
Note
Class and Model filters will use Lua's string.match
(which uses patterns) to check if the class/model matches.
This means that if you put just "prop", it will match as long as "prop" anywhere in the class/model. See the examples below for some common usecases.
findIncludeClass("prop") # All entites whose class contains "prop", ie "prop_physics" or "prop_vehicle"
findIncludeClass("^prop_physics$") # Matching exactly "prop_physics", ie not "prop_physics_entity"
findIncludeClass("^gmod_wire_[eh]") # Class begins with "gmod_wire_e" or "gmod_wire_h" (Using lua patterns)
findIncludeEntity(entity():isWeldedTo()) # Entity the E2 is placed on
findIncludePlayerProps(owner()) # All props owned by E2 owner
This whitelist will allow any entities that fit ANY (but at least one) of the above filters, so all your things, the entity the E2 is placed on as well as any entities which fit one of the class filters. The blacklist works in a similar way.
These are the functions that actually prompt the engine to look for entities. These all count towards the find quota.
These functions return the number of entities found. See below for retrieving the actual entities.
Function | Parameters | Explaination | Lua backend |
---|---|---|---|
findByName | string Name | finds all entites with the given name | ents.FindByName |
findByModel | string Model | finds all entites with the given model, supports * wildcards |
ents.FindByModel |
findByClass | string Class | finds all entites with the given class, supports * wildcards |
ents.FindByClass |
findInSphere | vector Center, number Radius | finds all entities with the radius around the center | ents.findInSphere |
findInBox | vector min, vector max | finds all entities inside the world-axis aligned box (min <= pos <= max for X, Y and Z) |
ents.findInBox |
findInCone | vector tip, vector direction, number length, number degree | See below | custom implementation |
Important
findByModel and findByClass do NOT use Lua patterns, unlike their filter counterparts.
findInCone
is a complicated one, it finds all entities which are within a certain angle from the direction and within the length.
It is much easier to just show an example usecase:
findInCone( Player:shootPos(), Player:eye(), 1000, 10)
will find all props that are within a 10 degrees circle of the players crosshair direction and within 1000 units.
See the wiremod source for more info.
Note that the E2 will never find itself or certain "weird" entities from the hardcoded blacklist, like spawnpoints or the physgun beam.
After a find operation the results are stored internally, and can efficiently be filtered by lua using the findClipFrom*
(to exclude something) and findClipTo*
(to exclude everything else).
You won't need these for most things, so feel free to skip this section.
These function will return the remaining number of entities after filtering. You can use any filters from the whitelist and blacklist and some additional ones:
findClipTo/FromName(string Name)
to filter the name. Just like the whitelist and blacklist filters for class and model you can also use partial strings or patterns here.
findClipTo/FromSphere(vector Center, number Radius)
to only allow entities inside or outside the defined sphere.
findClipTo/FromBox(vector Min, vector Max)
to only allow entities inside or outside the defined box.
findClipToRegion(vector Origin, vector Normal)
to only allow entities on one side of a plane defined by origin and normal.
Internally it checks if the direction from Origin
to the entity is within 90 degrees of the Normal
, or - for the math fans - (entpos-origin):normalized():dot(normal) > 0
.
Note that there is no findClipFromRegion
, as you just have to negate the direction vector to get the opposite side of the plane.
Again a practical example: (Player:shootPos(), vec(0,0,1))
would mean everything "above" (but not just straight above) the players eye position.
findSortByDistance(vector position)
doesn't strictly fit in this phase, but it is quite useful. It will sort all entities in the result list by their distance from the given position from near to far and also return the number of entities in the list.
You can get the results from a find operation in a few different ways, depending on what you need:
find()
will get you the first entity from the top of the list, and findResult(N)
will give you the N-th entity.
findClosest(vector position)
will get you the entity that is closest to the position.
findToArray()
and findToTable()
allow you to retrieve the full result list, either as array or in the numeric part of a table.
You can call as many functions to retrieve results as you want, and even refine the results furthing by clipping or sorting. This will not count against the find quota, so sometimes find operations can be "saved" by smart usage of clipping.
Find entities in a box
if (first()) { # only run the following code on chip spawn, as it creates holos
local Size = 1000 # Corner distance from chip. This is half the length of the created cube
local Chip = entity()
local MinCorner = Chip:pos() - vec(Size) # note that findInBox is always axis aligned and the second vector must be greater in all axis
local MaxCorner = Chip:pos() + vec(Size)
holoCreate(1, MinCorner, vec(1 + Size*0.0015))
holoCreate(2, MaxCorner, vec(1 + Size*0.0015))
findExcludeEntity(Chip) # Blacklist the chip from being found
findExcludeClass("gmod_wire_hologram") # Blacklist any entities with the class 'gmod_wire_hologram'
local NumInBox = findInBox(MinCorner, MaxCorner) # do the actual find operation, get number of results
findSortByDistance(Chip:pos()) # sort results by distance
local Results = findToArray() # export the (now sorted) results to an array
print(format("Found %u entities in the box! Closest one is a %s", NumInBox, Results[1,entity]:type()))
}
Please do not alter the e2 docs ...
pages manually.
They are autogenerated from the E2Helper. In the future, this will hopefully be its own dedicated website or tool.
Basic Features: core, debug, number, selfaware,
string, timer
🌎 World: angle, color, find, ranger, sound,
🔣 Math: bitwise, complex, matrix, quaternion, vector, vector2/4
📦 Entities: bone, constraint, egp, entity, hologram, npc
👨 Players: chat, console, player, weapon
📊 Data storage: array, files, globalvars, serialization, table
💬 Communication: datasignal, http, signal, wirelink,
❓ Informational: gametick, serverinfo, steamidconv, unitconv
Disabled by default: constraintcore, effects, propcore, remoteupload, wiring
Wire-Extras (repo): camera, ftrace, holoanim, light, stcontrol, tracesystem
Expression 2 ⚙️
- Syntax 🔣
- Directives 🎛️
- Editor 🖥️
- Ops 📊
- Learning & Getting Help 📚
- Triggers ⏲️
- Events 🎬
- Find Functions 🔍
- Physics 🚀
- EGP Basics 📈
- Lambdas λ
- Lambda Timers λ⏲️
- Tips & Tricks 📘
Click To Expand
- 🟥 SPU
- 🟥 Address Bus
- 🟥 Extended Bus
- 🟥 Plug/Socket
- 🟥 Port
- 🟥 Transfer Bus
- 🟩 GPU
- 🟥 Dynamic Memory
- 🟥 Flash EEPROM
- 🟥 ROM
- 🟧 Beacon Sensor
- 🟧 Locator
- 🟧 Target Finder
- 🟧 Waypoint
- 🟥 XYZ Beacon
- 🟩 CPU
- 🟩 Expression 2
- 🟩 Gates
- 🟥 PID
- 🟧 CD Disk
- 🟥 CD Ray
- 🟧 DHDD
- 🟥 Keycard
- 🟥 RAM-card
- 🟧 Satellite Dish
- 🟧 Store
- 🟧 Transferer
- 🟥 Wired Wirer
- 🟧 Adv Entity Marker
- 🟧 Damage Detector
- 🟧 Entity Marker
- 🟧 GPS
- 🟧 Gyroscope
- 🟥 HighSpeed Ranger
- 🟧 Laser Pointer Receiver
- 🟥 Microphone
- 🟧 Ranger
- 🟧 Speedometer
- 🟧 Water Sensor
- 🟧 7 Segment Display
- 🟥 Adv. Hud Indicator
- 🟧 Console Screen
- 🟧 Control Panel
- 🟧 Digital Screen
- 🟧 EGP v3
- 🟧 Fix RenderTargets
- 🟥 GPULib Switcher
- 🟧 Hud Indicator
- 🟧 Indicator
- 🟧 Lamp
- 🟧 Light
- 🟧 Oscilloscope
- 🟧 Pixel
- 🟧 Screen
- 🟧 Sound Emitter
- 🟧 Text Screen
- 🟩 Cam Controller
- 🟧 Colorer
- 🟧 FX Emitter
- 🟧 HighSpeed Holoemitter
- 🟧 HoloEmitter
- 🟧 HoloGrid
- 🟥 Interactable Holography Emitter
- 🟥 Materializer
- 🟥 Painter
- 🟧 Adv. Input
- 🟧 Button
- 🟧 Constant Value
- 🟥 Door Controller
- 🟧 Dual Input
- 🟧 Dynamic Button
- 🟧 Eye Pod
- 🟧 Graphics Tablet
- 🟧 Keyboard
- 🟥 Lever
- 🟧 Numpad
- 🟧 Numpad Input
- 🟧 Numpad Output
- 🟧 Plug
- 🟧 Pod Controller
- 🟧 Radio
- 🟧 Relay
- 🟧 Text Receiver
- 🟧 Two-way Radio
- 🟧 Vehicle Controller
- 🟥 Door
- 🟥 Adv. Dupe. Teleporter
- 🟥 Buoyancy
- 🟧 Clutch
- 🟧 Detonator
- 🟧 Explosives
- 🟧 Explosives (Simple)
- 🟥 Forcer
- 🟩 Freezer
- 🟧 Gimbal (Facer)
- 🟧 Grabber
- 🟧 Hoverball
- 🟧 Hoverdrive Controller
- 🟥 Hydraulic
- 🟧 Igniter
- 🟧 Nailer
- 🟩 Prop Spawner
- 🟥 Servo
- 🟥 Simple Servo
- 🟧 Thruster
- 🟥 Touchplate
- 🟥 Trail
- 🟩 Turret
- 🟩 User
- 🟥 Vector Thruster
- 🟥 Vehicle Exit Point
- 🟧 Weight (Adjustable)
- 🟧 Weld/Constraint Latch
- 🟥 Wheel
- 🟥 Wire Magnet
- 🟥 Wired Npc Controller
- 🟧 Debugger
- 🟥 GUI Wiring
- 🟥 Multi Wire
- 🟧 Namer
- 🟥 Simulate Data
- 🟩 Wiring
- 🟥 Beam Reader
- 🟥 Implanter
- 🟥 Reader
- 🟥 Target Filter
- 🟥 User Reader
Gates 🚥
Click To Expand
TBD