OfficeHours:ProbablePrime:2023-03-21

From Neos Wiki
Jump to navigation Jump to search

<< Previous Next >>

Audio

Description

In this Office Hours, Probable Prime talks about:

No description available, sorry!

Transcription

(Please note that the transcriptions will not be 100% accurate)



Welcome to Office Hours, it's your weekly half hour segment where I answer questions

about Neos.

We go ahead and get questions answered based on the questions and the order that they appear

inside the thread, so get those questions entered into that thread, and I'll get them

not answered in the order that they appear in.

If you're not sure what's going on, check the Office Hours check chat, the chat is above

the one you're currently in.

Looking at the list we have a few questions lined up, so go ahead and get those answered

whilst I try and find my English language inside my brain.

Spex asks, "Now that MMC is done this year, what's on your plate for Neos things?

Got any projects you're waiting to get into?"

Not really, just the same projects that existed that were kind of just delayed by MMC.

I got to the end of last week, sort of Sunday, which is yesterday, no day before yesterday,

and I sort of thought like, "I haven't done anything this week!" and then I looked and

was like, "Um, no, you kind of, you know, ran the voting for the rest of the weekend,

that's last weekend, or weekend before last, sorry, time is confusing."

You know, ran the voting, judged the entries, rehearsed the award show, went to the award

show, like lots went on, it just didn't feel like it did, so I was productive last week.

But yeah, that's all over now, so back on other things.

As a reminder for those who don't know what the MMC is, or even those that do, even if

you won, lost, entered, didn't enter, whatever it is, just remember that the stuff that is

created at the MMC can be created at any point during the year, you don't need the MMC as

an excuse to make it, so carry on making cool stuff in EOS, I love seeing it.

Moving forwards to the next question there, which is from Lex, who says "When silencing

a user through the sessions tab, the one that mutes a user for everyone, does that user's

voice audio stream stop being transmitted, or does it set the volume to zero?"

I don't know, I'd have to open the codebase and go take a look, I'll go ahead and get

that open, and then I'll dig back into it when I get a chance, as we go through the

normal ebb and flow of questions.

Unnamed Cyborg Cat says "Ever heard of Copy Kitty?

It's an amazing game the devs worked on very hard on, super underrated."

I have not.

I have like 1,800 games on Steam, and like 2,000+ on my wishlist, so probably it's on

there, I don't know though.

And with that, all the questions are over, I'm gonna mute Tech Humongous, Tech Humongous

scops of water, and then I'll be back.

And I'm back, there are no additional questions, if you have additional questions drop them

in the office hours texture, I'll get to them in the order that they appear in, whilst there

are no questions I'm just gonna sit here and think about cheese.

You'll be pleased to know my Amazon order has shipped, I don't know what it is, I don't

remember what it is.

What shipped?

I don't know, I'll figure that out later.

I was just reading the code on silence, looks like it will actually prevent the audio from

being transmitted, don't quote me, do your own testing, but based on my limited understanding

of how that works, it won't write to the value stream.

We have a question here from UnnamedCyborgCat, who says "Does Nio support any proprietary

mobile formats in the Source Engine?"

So the Nio's wiki has a list of stuff which people have looked at, and sort of work-ish.

Some of the problem here is that we, it's like, what we support isn't entirely up to

us, it's more up to Asimp, which we use to import assets.

If it's supported by those, then it will sometimes work.

Sometimes there's extra work we have to do once Asimp has handed it to us, but you can

see a list there.

Is that an alphabetical?

Yeah, that's an alphabetical.

Alphabetical.

It's difficult because things like FBX are technically proprietary, so yeah, BS supports

a proprietary file format, FBX is technically proprietary.

Don't use FBX, by the way.

I read this question like three times before unmuting it, so I'll just go ahead and read

it again and then think about it some more.

Lex asks "Why does setting the parent of a slot using the set parent node of an invalid

or null to slot parents the from slot to root?"

Set parent with an invalid to parents the from slot to root.

I mean, it should just cancel the operation.

I also wish more nodes had failure states.

Let me take a look here.

What I want is more nodes to have on failure, so if it pulsed with onFail coming out of

set parent, then it would be good to do that.

The new parent will default to the root slot if you pass in null or an invalid value.

I think a lot of this is just like various sort of hacky patches that we've been doing

over the years to try and prevent null parents from happening.

Anywhere that touches the slot hierarchy model, we try and basically interject and say "hey,

you're about to null parent this, don't do that!"

No, don't do that.

The behavior change that you're requesting where it doesn't do that is something that

would be cool.

Unfortunately it would also be a somewhat breaking change though, because it would increase

the amount of times where the set parent node wouldn't do something.

Like ran out, it would basically not do something if the thing you're trying to parent is null,

or if the new parent is a child of the target object, so you can't put something inside

itself.

In those cases it won't output failure, it will just literally do nothing, there will

be no output.

I hate nodes that don't have an output, because it's just very difficult to operate with.

It just defaults to world root if there's a problem.

Rampa says "nulling parent should just make nears destroy stuff, it has no parent so it

can't exist."

No not really, so while you, and I say you with a bunch of people who write mods in here

that know I'm wrong, but generally speaking, you are only able to access one hierarchy,

which is the world root hierarchy.

There are other hierarchies of slots and other types of components, and other lists and other

tree-based systems that exist outside of that system that some of this stuff operates in,

and so it's incorrect to say that if it's outside of the world root, it should be deleted.

It's kind of correct to say that it should be deleted if it doesn't have a parent, but

then again we should try and correct that rather than deleting it.

Your MMC project accidentally parents itself to null.

Yeah we delete it instead of trying to save your work for you and send it back to the

world root.

It's one of those things where it's like, this is gonna, yeah, um, I, Lex says "people

who are intentionally using that to parent things to root, or people who have different

logics to catch an unintentional root parent shouldn't be doing that."

Yeah, they shouldn't be doing that.

In fact if you're using root slot and you're not the owner of the world, I question your

motives.

Always use local user space, it is for the most part the world root, but in those one

few cases where you have world management systems using local user space, will keep

those world management systems more performant and easier to use.

So local user space.

Local user space returns the parent of the user who is running the set parent operation.

There is usually no downside of using local user space, I can think of a couple of cases

but only in world management systems where that might be problematic, so just use local

user space.

The amount of guns, RPGs, rocket launchers, grenades, bows and arrows, rifles, crossbows,

drink systems I see that are just like "cool, because I'm inconsiderate, I'll parent a bunch

of stuff to root when people use me."

It's like "cool, how about no."

So yeah, do think about that.

If you have a gun that produces, I should say entities, in a more traditional gaming

sense, like for those who are unaware, most guns in games are non-entity producing, so

they do bullets, and yeah sure bullets have animations, muzzle flash, smoke, explosions,

that sometimes traces the line that they take etc.

Those don't produce additional entities in the world, there's basically sort of a hitscan

with various complexities depending on what type of game it is.

Guns that produce entities are things like grenades, rocket launchers, the Needler from

Halo would be another good example.

They add additional stuff to the world when they are fired.

Crossbow and bow and arrow being a good sense, it sticks an entity to you.

Like a big rifle doesn't stick a world entity to the person, a bow and arrow does.

Which is kind of strange, because all weapons leave residue, guns leave impacted bullets

and casings and stuff like that.

I've never really seen a game make use of casings, sometimes they'll fall on the floor

but usually they're particle systems so they'll clear up after a bit, but I dunno, maybe it'll

be funny in a random shooting game, you start tripping over yourself if you stand still

for too long and start firing, you just can't keep your feet still when there's like casings

rolling under your feet.

Casings are usually quite easy to squish though, like dropping a bag of marbles on the floor

but just because you've been firing in the same place for too long.

Specs, actually let's go through a couple of comments here, so, Rampus says "the only

thing I can imagine not using user space is death effect".

No, user space should still work, because it'll parent above the user, not in the user.

If your world management system deletes the slot pertaining to the user when they leave,

then yes though, depends what's going on.

And test those, like extremely test them, it's difficult to test something where it's

like "when I leave the world, do something I can't see", because you're gone, but you

know what I mean, be careful.

Lex says "it's always funny when I see people using custom parenting systems to attach to

someone, then de-parent themselves to what a parent or parent thought they were in, and

get deleted when the user they previously parented to leaves".

Yeah, I've seen that happen a lot.

Virtual parent might be a solution there, if you know that it might be an unstable user

connection who might leave.

Specs says "there's a lot of cases where I've seen folks rely on uninitialized behaviour

and logics like that, and I have to admit it makes me wince.

No should users specifically initialize logics nodes with values instead of relying on default

behaviour that may change at any moment, unless a node is like a specifically duplicated design

to have an initial value that has some promise not to change without notice".

Yeah, nulls are terrible.

I am quite liking nullables in some C# projects I'm in right now, but it's just really annoying

like how much it comes up.

If you look it up, there's various articles, various quotes, various versions of it.

Someone in the computing world invented null, and they regret it.

I don't remember exactly who it was, it was either, I don't remember the name, it was

one of the big computer people from early on in computing.

It's the same thing with, the easiest way to identify null is if you look at a boolean.

So a boolean has true or false, on or off, yes or no, whatever you want to say.

But then with null, you introduce a third state of boolean, which is "I don't have a

value", and that's what null means in that case, "I don't have a value".

And that's perfectly fine to be used as "I don't know" or "I don't have a value because

I'm not initialised yet", but make that a value in your program.

Make the value be "I am initialised", not "I am null".

A good example of that comes up is in the sort of task-based system that C# has.

You have to wait for a task to complete, that's great.

Instead you could have written that and C# developers would have had hate about it, where

whilst you're waiting for a web request to happen, you have to while loop over the result

of that web request and check if it's not null, and you'd be like "Ah, it's happened!"

Instead they made this whole task system where it's like "Has the task completed?

The task has completed, here is the task's result".

And so it's like sort of implicitly built into the API that null doesn't occur, even

though it still does when people do tasks that return null for some reason.

When you're programming you should always be wondering "What do I do when X Y Z happens?

What do I do when X Y Z happens?"

If the code is telling you there's a possibility that null could exist here, you need to handle

it.

Like "Oh, the result of this method operation could be null, what are we going to do about

that?"

Same thing with objects though, we need more onFails.

What if the parenting fails, I need to know about it.

Yeah I don't like people who do that.

I always add the default of 0 anyway and people question why and I say "Well, it's there,

I can change it if I need to, I don't usually need to, but I also find it a little bit easier

to sort of compute in my head when I can see the default value, otherwise I have to remember

extra information, not only what the default value is, but is the default value acceptable

for that occurrence?"

For those who are like "Well I don't like adding the default value because that's an

extra slot", just go away.

Like it's one extra slot, come on.

I mean in most cases it will default to 0.

In cases where we have changed the default value of something, we are able to upgrade

logics to inject the old default value.

We did that once with findChildByName or something like that.

Say for example, I don't know, the inputs to + default to 0, let's say they change to

1, for some ungodly reason, the world would be quite screwed up for that to happen.

But we would basically, when we load your logics back in, we would detect "Hey you haven't

specified a default, so we will default this to 0".

And preserve the old behavior by automatically injecting a 0 input node for you, and that

way you'll be fine.

It might be the divide node, let me see, div float, nah, I forgot about that, yeah.

The divide nodes will allow divide by 0 errors, I forgot about that.

That's why we have the filter invalid node, to get rid of those cases where you have an

invalid value.

I always put, or try to, I often forget, I try to put filter invalid in places where

a 0 might occur with user input.

For example if there's a form field where they're entering a number, if they need to

clear out all of the number to enter their new number, then it might, for an update or

two, it might have a 0 in it.

And a couple of times that stung me and broken something, because I don't expect there to

be a 0 there, so filter invalid helps with that.

For example the value graph recorder, or it might be the graphing mesh, can't remember

which, it doesn't like if the number of values that it can store is less than 2.

It has to be 2 or greater, or it breaks and disables itself.

>> Are there any additional questions?

We've got about 5 minutes left in this office hours segment, we could talk about much more

programming stuff for a long time, or we could, any questions that happen, go for them.

Whatever you feel like.

>> Whilst I wait for questions.

There's a TV show on Netflix called Shadow and Bone, I don't know what it's called.

Shadow and Bone, yeah there we go.

Shadow and Bone.

I was quite enjoying it until they literally resolved the entire storyline in the finale.

Like there were a couple of episodes in the middle of the first season where nothing was

happening, and in the last episode an entire season worth of content happens and I'm just

like, "Guys, this isn't how you end a season."

You know, it's just like, "Oh yeah, it's mid-season episode, the characters have a cup of tea."

End of the season.

The characters travel halfway across the world, defeat the big baddie, throw the ring into

Mordor, and go home.

Very annoying.

>> So Lex asks, "Would you possibly know when closing a session, sometimes it doesn't happen,

immediately it takes a few seconds to kick everyone and then close."

I think it's resolving stuff.

There's stuff it has to resolve.

Like for example if you're saving the world, that's going to add extra time to it closing

of course, but if you're not saving the world, there's got to be something that's resolving.

I'd have to look into it.

There's got to be something that's preventing it from closing, some sort of process that

needs to finish or something.

>> Nationwide asks, "Why do sessions that have been open for about three days start

to get all funky?

Do my headless pack all logics into the world into a single random thought?"

It did that by itself, or did it do that when you next tried to pack logics?

That sounds like it shouldn't...

I can understand if it's funky how you packed it.

Yeah, so after about three days, numbers start getting weird.

Like I know tea has issues, but I haven't really worried about that.

Like if you see tea getting issues, it's like you're doing something wrong probably.

So input tea will get funky after a little while.

I don't remember exactly how long, but it's basically when floating point imprecision

takes over and the value of tea starts getting funky if you use tea for everything.

Then maybe it ran out of like...

I don't know if it ran out of references or something?

I don't know why that would happen.

Dynamic impulses should be fine as well.

I'd have to look into the numbers involved with packing.

It's by sure a number problem.

It just doesn't look like it.

It's something...

We have one more question.

So I was distracted by reading through the logics to see what was going on there.

Ishimwade asks, "one more very quick, does the headless client have a memory leak?"

It's possible that the entirety of Neos has a memory leak.

Sometimes I have to remind people, and I get all the circumstances and everything, I'm

not here to talk about them, but I'm here to state facts.

When it comes to the headless client, you are playing with an alpha pre-release of a

feature for an early access beta video game.

So yeah, it's possible it has a memory leak.

All right, that is half past and I don't see any more questions coming.

So I'm going to go ahead and leave things there.

As a reminder, if you have questions, please feel free to direct message them, drop them

in the questions and help channel, or send a carrier pigeon my way.

I'll get to them as soon as I can and I will speak to you guys next week