Scripting Helpers is winding down operations and is now read-only. More info→
Ad
Log in to vote
0

Trying to remove all tools from backpack?

Asked by 9 years ago
for i,v in pairs(game.Players:GetPlayers()) do
            children = v.Backpack:GetChildren()
            children:remove()
        end

Just learned about this kind of code and I am trying to remove everyone's tools from their backpacks. The code I was trying to write was supposed to get all the players, find their backpack, get everything that is in the backpack, and then remove it. Is there a better way to do this? The error code I receive tells me it is trying to remove a nil value. Ty for the help! :D

2 answers

Log in to vote
0
Answered by
Azmidium 388 Moderation Voter
9 years ago

Well your issue is you aren't looping through the players stuff once you get the stuff. You can't exactly remove children that way. Here is the fixed code, incase you need an example.

for i,v in pairs(game.Players:GetPlayers()) do
    children = v.Backpack:GetChildren()
    for i, v in pairs (children) do -- This loops through the player's stuff removing it.
        v:Destroy()
    end
end

You can also instead of looping through children do :ClearAllChildren() as this event is more efficient. The issue with it is that it doesn't remove the children. It changes the parent.

Hope this helped!

Sincerely, jmanrock123

0
both of you got this wrong. its :Destroy() not :remove() lukeb50 631 — 9y
0
There now it is Destroy lol. Azmidium 388 — 9y
0
I wouldn't use ClearAllChildren. It uses :remove(), so I'm not sure why it isn't deprecated already. Programmix 285 — 9y
0
:remove() works and I use it all the time. Azmidium 388 — 9y
View all comments (3 more)
0
It just sets the parent to nil, it doesn't destroy the object like destroy does. YellowoTide 1992 — 9y
0
Let me reword that sentence, lol. I knew that I just worded it wrong Azmidium 388 — 9y
0
It works. Thank you very much. Knew I missed a step heh. Noice. Malefactus 55 — 9y
Ad
Log in to vote
0
Answered by 9 years ago

Here's a fixed version of your script:

for _, player in pairs(game.Players:GetPlayers()) do
    for _, child in pairs(player:GetChildren()) do
        child:Destroy()
    end
end

Here's what changed.

First, we changed the top line, which was:

for i,v in pairs(game.Players:GetPlayers()) do

to this:

for _, player in pairs(game.Players:GetPlayers()) do

The only real difference here is the naming scheme. Calling a variable _ is the common practice for a variable that you don't use in Lua. We also name the second variable player, since that's the player object we're dealing with.

Next, we changed this:

children = v.Backpack:GetChildren()
children:remove()

to this:

for _, child in pairs(player:GetChildren()) do
    child:Destroy()
end

First of all, you can't call methods on the result of GetChildren, since GetChildren returns a table of objects. A table of objects doesn't have regular ROBLOX methods, so we have to iterate through it and perform actions on each one using another for loop.

Another key thing to note is how we use Destroy instead of remove in the modified version. remove is a deprecated method that has garbage collection issues. (don't worry if you don't know what garbage collection means)

I hope this helps you out. Good luck!

Answer this question