Lol "There's three of us now!?" "You and I work together a lot." 😆👍
@subliminalcastillo21264 жыл бұрын
That part made me laugh my ass off hahaha
@IsmaelSerrada4 жыл бұрын
Changing to Rider IDE was one of the best choices I made as a programmer, saves time, suggest appropriate changes to my code, and let me set up other conventions that may not be the default ones. I like these videos, there is always room for improvement when coding in any type of workflow. Keep up the good work.
@josh_swanson4 жыл бұрын
Damn, that skype video quality is next level!
@ewwitsantonio4 жыл бұрын
Can you pitch shift Barles' voice down an octave and give him one of those technicolor hats with the propeller on top please thanks
@modiddymo4 жыл бұрын
ewwitsantonio he’s waiting to give those to Gnarles when he drops the mob coding episode
@mrgetrext2972 жыл бұрын
This video formatting is amazing, definitely earned my sub
@subliminalcastillo21264 жыл бұрын
What I do instead of copy and pasting code, is I retype the code & even modify it as I am going. This way I get a much more intimate experience with each part of the code, and can also understand it better as I'm figuring out how I should break it up, style, & rename all the pieces of it.
@CreativeSteve694 жыл бұрын
I have to say Infalilible Code I'm glad that I found your channel back in 2016 when I first got interested how GameDev works. I love how you bring sketch comedy format into something well through educational content. I learn a lot through this method please keep it up. :)
@faythe034 жыл бұрын
In the last couple of days I have been reading about the Microsoft coding conventions, so this video came out at the right time for me!
@TNTCProject4 жыл бұрын
Love how you edit your videos. Good job!
@iercan12343 жыл бұрын
watched this in 4K it saved my life
@EricKesterson4 жыл бұрын
As you state in the video having a convention for your code at all is more important than worrying about which convention to use. I wanted to make an argument however for always prepending class member references with "this." (for example a variable declared as private float speed; would be referenced using this.speed. The reason I favor that approach is because "this" is a language feature that can only be interpreted in one way (the way the language interprets it). I've seen many different uses of "_" in unity code and you can find yourself confused when swapping between your own code, unity documentation, and downloaded / copied / tutorial code. Sometimes private members are prepended with "_", sometimes method arguments are prepended with it. I come from Java software development which is where I picked up this standard, however some of the Unity examples also use it (though the unity docs seem to be some of the most inconsistent styled code anywhere). Allowing an IDE such as Rider to provide formatting is also a good argument, however I have not yet switched to Rider myself. As for public vs private, personally I haven't actually found it to be extremely important to differentiate between them when reading through code, so I don't bother to differentiate their naming. To be clear, I do carefully consider what members should be public or private, but once that contract is established, I don't usually need to consider it any further, so I don't use a naming convention to keep them visually distinct. Knowing which variable is a member and which is a method argument has proven much more valuable to me. These approaches have done well for me as a hobbyist Unity developer for the past 5-ish years and as a software developer for the past 15. As stated in the video this will always be a divisive topic, and I don't intend to detract from valid arguments for other styles, just offer my own experience.
@fmproductions9134 жыл бұрын
Important concept to cover to, and I like the brought up reasons on why to do it: - Making it easier to read and understand the code (and a well fitting blog post structure analogy) - thinking about you as a past self/current self and a future self that might come back to the project in the future while perhaps having forgotten a few things about it already. Thanks for the vid!
@artcadedev Жыл бұрын
By the time I saw the thumbnail you had already earned a sub
@JewGames3 жыл бұрын
Your videos are great, so much dedication and work on each video you do, amazing please keep it up! :)
@InfallibleCode3 жыл бұрын
Thank you so much!
@Tarodev2 жыл бұрын
I'm working on a conventions video (might be a little more passive aggressive than this video...) and I loved your concept of there always being at least two people working on the project. Do you mind if I quote you with attribution on my video?
@shieldgenerator74 жыл бұрын
In Visual Studio, use CTRL+K, CTRL+D to autoformat the current file.
@Matthew-zs8nm2 жыл бұрын
Bro, you're hilarious. This was also a great video for a beginner like myself. Subscribed.
@DeathxStrike182 жыл бұрын
I tend to do Public Field > HideInInspector Public Field, Serialized Private Field, Private Field. My logic is the more exposed variables are at the opening of the Script with more secure variables deep within the script. Open > Closed formatting. Think of the script as a box the deeper you dig into the box the harder to get to the items.
@Gaisiran3 ай бұрын
A pleasure to watch!
@Spherous4 жыл бұрын
Another great video! Keep it up! I really like your format, by the way, flows well.
@sebastianbryant42162 жыл бұрын
Great video as always!
@InfallibleCode2 жыл бұрын
Thank you :)
@hansshadow3604 жыл бұрын
conventions begin at 3:20
@cuttlas29554 жыл бұрын
I love this channel and how simple it is to underestand thing here ,
@subliminalcastillo21264 жыл бұрын
"Wait. There's 3 of us now?" HAHAHA. That made me laugh so hard that i have a cramp in my chest now.
@PandemoniumGameDev4 жыл бұрын
Awesome video as always! 🔥 Would love to get a tutorial on the most common mistakes that kill your game's performance and how they can be avoided.
@sparrowhawk814 жыл бұрын
What are your thoughts on how to handle modifying an asset you got off the Unity Asset Store? I haven't really come across the need to do this yet personally, but I know you are allowed to modify the source code of assets (the ones that aren't DLLs I mean) you get off the asset store for your own purposes, but I could see myself maybe wanting to rework something someday to add features to it or whatever. Obviously you could just dive in and go for it but have you come across this yourself? Any tricks with inheritance or anything that are useful? Wrapper classes?
@tylocook4 жыл бұрын
I came here to make a comment that you should not edit the source code of a big asset you import into your project just to style its code to look like yours. The example he used was a snippet of code from Stack Overflow which should not be confused with using somebody's hundreds of lines of code. Maybe Charles disagrees, but I can see why you're confused.
@StefanLopuszanski4 жыл бұрын
I modify them when needed, but try to avoid it because if something updates and fixes some bug I have to go through it manually.
@veeaxis38924 жыл бұрын
Is there any naming convention for delegates and events?
@lvx9694 жыл бұрын
Hold Control and press the E Key and then the D key to auto format spacing and tabbing in Visual Studio Community 2019.
@saito8534 жыл бұрын
Working with a friend on a project for my thesis, his naming convention SUCKS DICK and I'm sending this to him. Thanks for the great video Charles (and Barles)
@RobLang4 жыл бұрын
Complaining about m_ while still doing _. IDEs can colour variables by scope so you don't have to do that. Otherwise, love the video, great job.
@lucasmontec4 жыл бұрын
You can choose a convention with your team for your project that is close enough to the c# one but still more up-to-date. Your code base just have to be consistent with itself and across time.
@RobLang4 жыл бұрын
@@lucasmontec I completely agree that it's the choice of every team. In my team, it's my choice! 😀 The underscore is a hangover of Hungarian notation, which was phased out when IDEs became more interactive. 👍
@lucasmontec4 жыл бұрын
@@RobLang I have banned the use of underscore im every team I have worked with. We are in 2020, there is absolutely no reason to use it, just makes code ugly and hard to read.
@RobLang4 жыл бұрын
@@lucasmontec lol! Perhaps we should start a revolution?
@tylocook4 жыл бұрын
I like to use m_ or _ just so I can type those first characters and have intellisense show me all the member variables. I use it to categorize class level variables
@stefano49933 жыл бұрын
Great video! Totally agree about consistent naming. Just not sure about private and public methods. I try to keep them logically structured, also because of regions....
@risulkarim57814 жыл бұрын
Hey Charles, great stuff once again.. you guys are being my favorite couple of mentors :-D Just curious about which font you use? It looks so cool
@verified_tinker18184 жыл бұрын
3:31 I'm going to murder anyone who does this to my code. Nothing triggers me more than braces going below the declaration. It's ugly, inelegant, and almost never makes the code any more readable. On a brighter note, what's that font you're using? It looks rad!
@nooftube25414 жыл бұрын
Looks like you aren't from c# world :)
@neitron294 жыл бұрын
Personally, I hate Upper case for public members, because Unity`s libraries are written with lower case rule. Why Would you prefer to mess up with both?
@jorhoto70644 жыл бұрын
could be a way to distinguish between yours and Unity ones.
@nooftube25414 жыл бұрын
But you still using system lib, so it would be messed up anyway. Dat unity developers.....
@albertoravasio8494 жыл бұрын
Which visual studio do u use? It's different form the default one
@yuan32344 жыл бұрын
Its Rider IDE
@travelsizedlions4 жыл бұрын
You mean the bracket thing isn't the most polarizing?
@Redheadtama14 жыл бұрын
Hi Charles. Thanks again for continuing to teach best practices! You always give accurate and helpful info. If you don't mind, could I offer a little bit of constructive feedback? Please don't take it the wrong way. I honestly just want to help but feel free to ignore me if you disagree with my comments :). OK here goes: Personally I find the structure of these videos can distract a bit from the information you're providing. It can come across a little bit cringe and feels like it takes twice as long to put your point across. I say this because sometimes I find myself re-watching one of your videos to remind myself of something you said, but it's really difficult to find what I need because I have to filter through all this exposition and conversation between you and yourself. Again, thanks for your work on these videos. I honestly do appreciate it. Also I purchased Enhanced Hierarchy recently and it's been great so I will be sure to leave you a positive review on the asset store :).
@RayHorn51280880562 жыл бұрын
Why can't I use whatever code I want to write so long as it works?!?
@UsatiyNyan4 жыл бұрын
As a C++ dev I feel personally attacked by first brace not being on the same line as a class/function declaration
@nooftube25414 жыл бұрын
Dat c++ guys come to c# place their braces on same lines and leave... and c# guys have to leave with it...
@TheLucausi4 жыл бұрын
Where is the Civil War? Camel vs Pascal? just kidding. Your video is awesome, great coding conventions! ( Don't agree too much with underscore on attributes fields, but i love u anyway xD )
@Abken.4 жыл бұрын
Really good video. 👍 I always fight already lost matches with people on Reddit who hate conventions and they always dislike me when I say that public fields are bad. Everyone starts crying how they are not bad if they're used well. What's the problem with writing good code from the beginning. If I mention SOLID I instantly get 20 dislikes :D But reddit guys hate even properties.
@agnichatian4 жыл бұрын
Yeah, many people hate discipline.
@nooftube25414 жыл бұрын
Public fields doesn't related with SOLID anyhow. Actually no matter you use public field or property with public setter even from the point of encapsulation view, because both provides same API. The only problem with field that it is not obvious that it should or should not be changed from the outside, but a blind changing it to property won't make your class encapsulated.
@Abken.4 жыл бұрын
@@nooftube2541 This is true, but a wrong mentality. I'm so tired of this topic. My idea is that when you are creating a new class, you should make anything { get; private set; } if you don't need validation or another logic at this point. Then you realize that you need to expose a setter. There is no difference if you make the exposure through a method or through the setter, it's still an exposure. But at least you will think about "why do I need to expose this property, are there no other solutions to this problem, etc". This is way better than making everything public field and then going back to encapsulate only what you need, because you will ignore/skip unintentionally many cases where you can avoid data exposure. If you are a newbie C# dev, it will be much easier to just write every field as a property with private set and it will be much easier to understand why do you need to hide the unneeded data. That's why in universities the OOP topic is so important that the exams are literally "what's encapsulation, what's polymorphism, what's inheritance" instead of writing some code and solving real problems. It's important that the new devs will know why these things matter. Also I've never mentioned that public fields have anything related with SOLID, but if newcomers don't understand what's encapsulation and why it is important, how can we expect that they will follow SOLID on their desk job as web dev, game dev, etc.? And believe me, if you go to Ubisoft's Unity interview (they need Unity devs right now for a 3D game), they will ask you about OOP, SOLID and not ECS. If you look for ECS jobs - yes, they don't ask for such skills, because they have use almost no inheritance at all. ECS vs OOP is another topic. But yeah, it's easier to start from {get; private set;} and learn why it is needed. The most important thing that OOP teaches is discipline - it makes you write good readable code because not everyone works on its own project alone.
@nooftube25414 жыл бұрын
@@Abken. though I suggest never write public get property at first. Use readonly private fields, and only when you realize it is needed to be exposed, convert it to public property.
@Abken.4 жыл бұрын
@@nooftube2541 Yeah, yeah. I meant that if I need to expose data my workflow is - create a property without set, then add private set, etc. Of course that the other data that we don't need exposed should be private fields. And readonly is a good advice that many people that come from Typescript or C++ to C# do, but most of the C# devs don't do. But it's a good advice anyways.
@jorhoto70644 жыл бұрын
According to conventions should we use the prefix: _ for all our private fields? Option 1 or 2? E.g.: 1. private health 2. private _health
@EricKesterson4 жыл бұрын
personally, I always declare as private int health; and then when referencing I use this.health. My argument for using "this.health" is that it is the ONLY coding style that is also a language feature which CANNOT be interpreted another way. I've seen "_" used in many different ways, so if you jump between projects or copy some code you could easily become confused by its use.
@nooftube25414 жыл бұрын
As you prefer.
@halivudestevez22 жыл бұрын
I hated underscore for a long time ( used "this"). Now I started using it. Seems professional, and one more difference against the local variables in the method. _ health - class member private field health - local variable .... this._health - overwhelmed signature
@ujjwalgupta12044 жыл бұрын
Nice Video
@imxron4 жыл бұрын
The amount of time I've spent convincing teams I've worked on to use auto formatters / linters is almost as long as coming up with variable names. Ctrl + Alt + L 😉.
@benoitrousseau41374 жыл бұрын
Amusingly, Unity is at odds at a few places with the official C# style guidelines from Microsoft. For example, public fields should be pascal cased in C#. (ie Time.DeltaTime, not Time.deltaTime.) That said, I would use the Unity style when working in Unity.
@ujjwalgupta12044 жыл бұрын
new to the channel
@StefanLopuszanski4 жыл бұрын
No mention of where to put the { }? :-P
@Konomira4 жыл бұрын
3:42
@jorhoto70644 жыл бұрын
Hi, did anyone notice the 2 guys in the video are very similar?
@victrolaface4 жыл бұрын
Charles in charge, of my life, of my youtube.
@monkeyrobotsinc.98754 жыл бұрын
CLASSIC
@Patrick_Bard2 жыл бұрын
Coming from a cooperate Java background, curly brackets on their own line is the only rule I can't stand.
@ImranDaybyDay4 жыл бұрын
Charles is like Clark Kent
@Bossti4 жыл бұрын
Opening brackets on its own line make me sick ^^"
@Unavailable89233 жыл бұрын
Same here. It just pushes code off the screen by wasting vertical space.
@jorhoto70644 жыл бұрын
What if I have a class Health and a property Health? Should we name it the same? public class Health { public int Health {get; set;} }
@divingradish4 жыл бұрын
I would do this: public class Health { public int Value {get; set;} }
@nooftube25414 жыл бұрын
You can't do it. It won't compile.
@FuzzyDPozzy4 жыл бұрын
use underscore for private fields such as private float_number;
@Faygris4 жыл бұрын
I only use Hungarian pascal snake case. *private string M_Str_Prove_Me_Wrong;*
@InfallibleCode4 жыл бұрын
Lmao 😂
@razveck4 жыл бұрын
Ugh
@daniilparokonnyy79804 жыл бұрын
Should you use "_" or not - that is the question!
@alonsorobots4 жыл бұрын
you just snuck in the underscore before the variable without mentioning it!
@DoubleM554 жыл бұрын
I find it ugly having private fields start with underscore. Any IDE will not let you use private fields outside class, so I don't even see the point. If it was really important then compiler should check it, but it's redundant and pointless.
@doge92033 жыл бұрын
ah not the brackets
@InfallibleCode3 жыл бұрын
Darn those pesky things...
@ApacheGamingUK3 жыл бұрын
Why does Unity force people to break the C# Coding Standards? Intellisense is a total mess, and makes it so easy to break encapsulation.
@tomerssh4 жыл бұрын
6:37 my engineering career in a nutshell
@monkeyrobotsinc.98754 жыл бұрын
after speeding up ur vids to 1.25, i know that u slow them down before uploading them to youtube.
@АскольдМакарук4 жыл бұрын
I hate fucking skype tutor format so much but your videos are too damn informative
@andredias50613 жыл бұрын
my brains hurts... who am I? is there a life worth living? what's life? Is Life alive by itself?
@YuvrajRaghuvanshiS4 жыл бұрын
Curly braces on next line.... Noooooo
@ionthruster95724 жыл бұрын
recommend vs+Reshaper
@nooftube25414 жыл бұрын
Rider - x64, vs - x86 (and will never be x64). Checkmate.
@enriquellerena47792 жыл бұрын
m_ I remember that, what a pain. Xd
@unlockener4 жыл бұрын
Unity properties vs c# properties. Why bring more chaos to this world