You're actually touching the tip of a bigger iceberg -- unattended trailing whitespaces in source code. This is something that can raise conflicts in source controls. The best advice would be to configure your editor to remove them on save, because they should *never* stay around toward your commit.
@@smrtfasizmu6161 Yes, I know, two years late, but... While whitespace doesn't matter for most source files, Elad Galili was talking about source control, things like git, mercurial, and subversion. They don't check how your files compile, just if they're different, and having a single stray whitespace from, say, accidentally hitting the spacebar while reading through a section of code to make sure what you're writing in a different file or even compilation unit won't cause problems, can cause unnecessary merge conflicts and automatic version changes that you then have to go back and fix manually. It's not a huge deal to fix most of the time anyway; most text editors it's a pretty easy bit of scripting to automatically strip trailing whitespace.
You're welcome. Sometimes people encounter this, but don't realize it because they manage to fix it without realizing what they did. I know my first few run-ins with it back in ---a long time ago--- I ended up just retyping part of my makefile and it worked, and I just moved on, not realizing what I did wrong in the first place.
Oh, some of my most memorable experiences programming were when I almost went crazy trying to solve a silly problem :) Like when I split a file with CRLF endings with " " and my strings ended with . It absolutely messed up my output and I didn't even know that carriage return is a thing.
Thanks for another really good video. When you showed the make files I immediately guessed “I bet the indents aren’t tabbed in, but spaces were used”. I was wrong but it looks like another way whitespace can cause trouble. :)
Thank you Dr J. for this topic. Makefile whitespace has transferred to my scalp. I am a Makefile user who has struggled for hours to get one specific one working well and I failed. I will review my irritant Makefile. The fault: By changing one source file, of a dozen, the Makefile causes all sources to be recompiled. Fortunately, the code is stable. It is not your problem. But you incentivize me to revisit it again. Hopefully, my buglet will be discovered in a short time-span.
A better way to avoid a problem like this is to simply configure your editor in a way so that it removes all white spaces at the line ending automatically when saving the file. Theoretically this reduces also the file size. You usually won't notice the latter on a typical file system that is using whole blocks to store data, but when packaging the file with tools like tar or zip and transfering to another machine via network this can save some bytes.
I would use a utility to build the Makefile versus hand coding it. That way you also get the appropriate .h dependencies into the Makefile. I wrote a utility to create the Makefile back in the 90s and have been dragging it around with me since then.
Experienced a similar issue ,when setting tab = 4 spaces in the vim editor. we can differentiate the whitespaces and tabs by executing "set list" command in the vim.
CMake is a joke that went too far. Sort of like JS. You will probably have to learn it one day if you do C/C++ professionally. It's a defacto. I sad defacto. My experience with premake is good. As long as you don't do crazy things with lua.
I'll have to try out premake. I'm also not in love with cmake. I use Rake sometimes. Build systems are like friends. Most have both lovable things and annoying quirks. I guess who you invite to the party, depends on the kind of party you want to have. 🤔
I don't understand the hate on cmake especially considering people still use make instead. It might not have the best syntax ever but it works well and it is super easy to learn. It is so much better than make (even without taking into account that it is the de-facto standard) that it doesn't make any sense not to use it over make even for the simplest single file projects.
Thank you for your videos Jacob, they are really informative! Would you consider making a brief video on the "inline" keyword in C - what it's for, how it works, and how it should be used? Or can you recommend a source for a clear explanation? I've been reading up on it but I can't get a clear understanding myself 😕😕😕
@@samsawesomeminecraft Sadly, there isn't. There are a lot of different ways that a Makefile can be broken. If you point me to the online resource, I might be able to address it in a future video, though.
three things, first thanks for the video, this may have been a issue i had with make and decided to just make bash build scripts instead. second while on the topic of bash i just came across a whitespace issue with bash ( not putting spaces around brackets in conditions). third i believe newer versions of nano will highlight trailing spaces on a line by default (at least most of mine do).
Hi Jacob, You really did gave a lot of people gold (coz u save them a lot of time 😂). I also encountered this in my project which had a makefile untouched for almost 3 years and suddenly becoming erroneous. I spent many hours debugging and the solution is, white spaces. One thing to take note also is when update packages, make utility might also behave different. In my case GNU make 3.81 is OK and for some reason i performed a yum update which updated GNU make to 3.82 which causes the error. Anyway, more power in making these videos. Best Regards!
I learned makefiles from what I consider to be a great sample. The makefile written by Eric Weddington for WinAVR2010. Actually, instead of learned, maybe I should say I hacked it do do what I want...
This happened to me as well. The "same" makefile didn't work on my friends PC and I had to email him my file and only then it worked
4 года назад
Good practice is to pass your 'configuration' variables (variables which are changed more often, or for each project) through $(strip) function. You will never have similar problem anymore.
I've used python Invoke for task automation and build scripts, and recently I'm giving a try to xmake (Lua)... I always felt like writing makefiles was harder than trying to write in Klingon... And any python programmer knows to set it's ide or text editor to show whitespace all the time.
This sort of thing gets me riled up. I SWEAR i thought this was going to be the spaces-instead-of-a-tab thing that Make looks for in indented lines. (RANT incoming) The ASCII TAB character should be outlawed. As far as I know, MAKE is the only thing that requires it. TAB has an awful history. TAB originally meant "go to the next TAB position which is every 8 character positions from the start" which is 1, 9, 17, 25, 34, ... Every ASCII device (well, maybe not the ASR-33, I don't remember what it did) followed this standard, so any series of characters, spaces and tabs showed as the same thing on every CRT terminal and the DECwriter followed that convention. But then the microcompter came along, and then the word processors probably Wordstar, which took TAB to mean whatever the programmer(s) wanted it to mean, some odd predefined tabstop or four spaces or whatever This was in the word processor's own proprietary file format, which was almost forgivable, but it was surely not properly converted when the file was saved as ASCII. Nowadays even "straight text" programming editors let you tell it how far to move with the tab character. At least most can be configured to insert the appropriate number of spaces into the file instead of the tab, so it's possible to ... write Python with good formatting. No one uses tab to mean 8 spaces anymore anyway. Modern indenting is four, or maybe 3 or 2 spaces. So really the thing has lost all usefulness, and causes more problems than it solves. I can see where it originally saved extra space characters, but source code size in memory or on a hard disk is no longer a problem, and version control systems do data compression anyway. So I have Notepad++ set to insert spaces to get to the next four-space "tab stop" and I'm happy that my code will look the same in any text editor. But then in recent years I have this growing program I was splitting up into several source files, and I go back and look at the Make documentation for the first time in a few decades, and it REQUIRES a tab character ... If I had a dollar for every "you can fix ThisEditor to strip trailing spaces" comment I could invent a time machine and pay whoever first wrote Make to have it accept "one or more tabs or spaces" for an indented line, and always ignore trailing spaces.
Likely because it's a "legacy" thing and they're afraid to change it out of fear of somehow breaking something. There's no reason not to make Make more reasonable, it's not like it's part of any language spec, or part of Posix or anything, at least I don't think so.
I just have my editor (neovim) set up to both display whitspaces aswell as auto trim trailing spaces in any file I edit. I didn't know about this issue with make but that might be because I never had to encounter it
Those are just the names of the subdirectories that I'm using to build my project. SRC and OBJ are the variable names, the lowercase "src" and "obj" are just string literals.
The only reason I don't code in C is because compiling it always feels like a can of worms, and at this point I have no patience to try to solve the issues... :( EDIT: lol I just revisited a broken python script for compiling C that I made a while ago, and made it work. I am now able to compile C. To paraphrase a portuguese saying: when you don't have a dog, you hunt with a python. :D
The truth is that for the most of time, build tools aren't even needed. You can compile just fine using shell scripts. I don't know why people love complicating things.
I have seen problems with whitespaces after \ escape, which was supposed to be escaping a the newline, but there it was actually escaping a whitespace. It is a good practice to configure editors to display and optionally clean whitespace, potentially making use of plugins like editorconfig. It is not uncommon for me to open a file and get mad of the carelessness with trailing whitespace, to which I usually respond with a :%s/\s\+$::g 😅
Sir plz start embbeded programming on c language create own header files create own function on c plz sir start that tutorial i am waiting for this tutorial quite while
If, by any chance, make was a Microsoft tool, hellfire would break loose. Now I'm reading excuses and workarounds. Like claiming the car is good, despite breaks, sometimes, don't work over 60mph, but if you slow down, it might. I understand that make si an old tool, but warship it in the museum, don't recommend it anymore.
"... i know years of experience" ***proceeds to make rocket science out of white space*** isn't one of the first things you learn about make that it's white space sensitive
Yeah, I know. I do use YAML when it makes sense (just like I use python and make). But, their whitespace-based issues feel like unnecessary self-inflicted wounds.
Sure, but to be fair, I could say the same thing about seg faults, memory corruption, memory leaks, and just about any kind of programming mistake out there. Most everything is easy once you understand it.
2:09 "If it's still giving you errors, think about whitespaces" this helped me fix an issue!
"You spend hours pulling your hair out if you have hair" lol
@Loraine Longworth Google for what? You being a terrible boyfriend?
You're actually touching the tip of a bigger iceberg -- unattended trailing whitespaces in source code. This is something that can raise conflicts in source controls. The best advice would be to configure your editor to remove them on save, because they should *never* stay around toward your commit.
Very true. Thanks for mentioning that.
Ah, good tip. I wonder what other annoyances we live with that editors have a setting for but we never think to look for it.
That doesn't matter for source code of programming languages. C, Java don't care about white space.
I fanatically use git diff before committing as it highlights trailing white space.
@@smrtfasizmu6161 Yes, I know, two years late, but... While whitespace doesn't matter for most source files, Elad Galili was talking about source control, things like git, mercurial, and subversion. They don't check how your files compile, just if they're different, and having a single stray whitespace from, say, accidentally hitting the spacebar while reading through a section of code to make sure what you're writing in a different file or even compilation unit won't cause problems, can cause unnecessary merge conflicts and automatic version changes that you then have to go back and fix manually. It's not a huge deal to fix most of the time anyway; most text editors it's a pretty easy bit of scripting to automatically strip trailing whitespace.
I think I saw it! Tabs vs spaces. This gave me a headache in the past.
Me too.
same.
it's like restarting the computer, before you try anything with a makefile, check the tabs.
You could enable the trimming of trailing white-spaces when saving the file in the preferences of VS Code.
This is a really high production-value to a students question!! I wish all of my professors would answer my emails like this!
I have actually never encountered this, but interesting thank you.
You're welcome. Sometimes people encounter this, but don't realize it because they manage to fix it without realizing what they did. I know my first few run-ins with it back in ---a long time ago--- I ended up just retyping part of my makefile and it worked, and I just moved on, not realizing what I did wrong in the first place.
Oh, some of my most memorable experiences programming were when I almost went crazy trying to solve a silly problem :) Like when I split a file with CRLF endings with "
" and my strings ended with
. It absolutely messed up my output and I didn't even know that carriage return is a thing.
Great work man! Love your channel topics and vibes!
Thanks, Matias.
Tip: highlight the whole file in your editor and look line-by-line for that one bit of whitespace.
Hi Jacob. I really like your videos. It guides me to lots of sections of computer science. This is really helpful please never give up, keep it up.
Thanks, will do!
Thanks for another really good video. When you showed the make files I immediately guessed “I bet the indents aren’t tabbed in, but spaces were used”. I was wrong but it looks like another way whitespace can cause trouble. :)
Thank you Dr J. for this topic.
Makefile whitespace has transferred to my scalp. I am a Makefile user who has struggled for hours to get one specific one working well and I failed.
I will review my irritant Makefile. The fault: By changing one source file, of a dozen, the Makefile causes all sources to be recompiled. Fortunately, the code is stable.
It is not your problem. But you incentivize me to revisit it again. Hopefully, my buglet will be discovered in a short time-span.
A better way to avoid a problem like this is to simply configure your editor in a way so that it removes all white spaces at the line ending automatically when saving the file.
Theoretically this reduces also the file size. You usually won't notice the latter on a typical file system that is using whole blocks to store data, but when packaging the file with tools like tar or zip and transfering to another machine via network this can save some bytes.
Jacob you're the CS teacher I never had! Thanks for being yourself!
You're welcome. Glad I can help.
Had a problem with a make file yesterday that I copied online to learn about Linux kernel modules. This was the issue. Thank you!
You're welcome.
I would use a utility to build the Makefile versus hand coding it. That way you also get the appropriate .h dependencies into the Makefile. I wrote a utility to create the Makefile back in the 90s and have been dragging it around with me since then.
Tip: also, many editors have this option of remove trailing whitespaces on saving file or exiting or smth like that. Be sure to look into that too (:
Experienced a similar issue ,when setting tab = 4 spaces in the vim editor. we can differentiate the whitespaces and tabs by executing "set list" command in the vim.
What do you think about make alternatives, like premake or CMake?
CMake is a joke that went too far. Sort of like JS. You will probably have to learn it one day if you do C/C++ professionally. It's a defacto. I sad defacto.
My experience with premake is good. As long as you don't do crazy things with lua.
I'll have to try out premake. I'm also not in love with cmake. I use Rake sometimes. Build systems are like friends. Most have both lovable things and annoying quirks. I guess who you invite to the party, depends on the kind of party you want to have. 🤔
I don't like make but really like CMake. It looks a little messy the first time, but in the end it's pretty cool.
I can only wonder if these other make utilities have the same "features" as the original make in order to 'maintain compatibility'.
I don't understand the hate on cmake especially considering people still use make instead. It might not have the best syntax ever but it works well and it is super easy to learn. It is so much better than make (even without taking into account that it is the de-facto standard) that it doesn't make any sense not to use it over make even for the simplest single file projects.
Many editors have and option to remove tailing whitespace from files when saving.
Before staging you can run git diff and the whitespaces are shown with red background
Just a note on Vim you can use :syntax on :set syntax=whitespace
This really saved me money from a visit to the therapist! Thanks Jacob!
Thank you for your videos Jacob, they are really informative! Would you consider making a brief video on the "inline" keyword in C - what it's for, how it works, and how it should be used? Or can you recommend a source for a clear explanation? I've been reading up on it but I can't get a clear understanding myself 😕😕😕
I've added *inline* to my list. Can't promise when it will come out. Hopefully, in time to be useful to you.
@@JacobSorber Thank you so much!
Unrelated - What is your camera and lighting setup Jacob? Looks really good. Sharp + well-lit
every time i have to drop back down into c i become exponentially more thankful for cargo
what if I downloaded some source code from the internet and try to use the Makefile there and it produces an error?
Well, that depends on the error (and the Makefile).
@@JacobSorber so there's no easy fix?
@@samsawesomeminecraft Sadly, there isn't. There are a lot of different ways that a Makefile can be broken. If you point me to the online resource, I might be able to address it in a future video, though.
@@JacobSorber I had trouble compiling this from source github.com/nigels-com/glew
In Geany there is 'Strip Trailing Spaces' command.
You could also use Emacs, which by default trims all white spaces in Makefiles on save.
three things, first thanks for the video, this may have been a issue i had with make and decided to just make bash build scripts instead. second while on the topic of bash i just came across a whitespace issue with bash ( not putting spaces around brackets in conditions). third i believe newer versions of nano will highlight trailing spaces on a line by default (at least most of mine do).
Hi Jacob,
You really did gave a lot of people gold (coz u save them a lot of time 😂).
I also encountered this in my project which had a makefile untouched for almost 3 years and suddenly becoming erroneous. I spent many hours debugging and the solution is, white spaces.
One thing to take note also is when update packages, make utility might also behave different. In my case GNU make 3.81 is OK and for some reason i performed a yum update which updated GNU make to 3.82 which causes the error.
Anyway, more power in making these videos.
Best Regards!
Thanks, Artemio.
I've never been able to follow some of those bigger project's makefiles. theirs seem to try to cover all edge cases.
Vscode has a setting that clears trailing whitespaces on save
Used to show all whitespace characters in vi or emacs
advanced information thanks again
that's why my Vim is always configured to rendre whitespace characters
I learned makefiles from what I consider to be a great sample. The makefile written by Eric Weddington for WinAVR2010. Actually, instead of learned, maybe I should say I hacked it do do what I want...
This happened to me as well. The "same" makefile didn't work on my friends PC and I had to email him my file and only then it worked
Good practice is to pass your 'configuration' variables (variables which are changed more often, or for each project) through $(strip) function. You will never have similar problem anymore.
how can i open a makefile to see the codes!
Man, I was so sure it was that the broken version used spaces instead of tabs. :(
Hey jacob, can you share your shell theme? Thanks in advance :)
I use vimdiff to see the difference between 2 files. Will that help?
Notepad++ -> view -> Show Symbol -> Show all symbols
Cool thanks.
That's why I use CMake
Hello there,
Kindly tell me what does makefile. Win has changed mean?
And how to fix it?
I've used python Invoke for task automation and build scripts, and recently I'm giving a try to xmake (Lua)... I always felt like writing makefiles was harder than trying to write in Klingon... And any python programmer knows to set it's ide or text editor to show whitespace all the time.
Editors nowadays also have the option to remove pointless whitespace characters when you save the file.
😊 🙏 😊
thanks for explaining the issue. make should have a built-in linter...
Agreed. It definitely seems like there are some easy things that make could check for us automatically.
This sort of thing gets me riled up. I SWEAR i thought this was going to be the spaces-instead-of-a-tab thing that Make looks for in indented lines. (RANT incoming)
The ASCII TAB character should be outlawed. As far as I know, MAKE is the only thing that requires it.
TAB has an awful history. TAB originally meant "go to the next TAB position which is every 8 character positions from the start" which is 1, 9, 17, 25, 34, ... Every ASCII device (well, maybe not the ASR-33, I don't remember what it did) followed this standard, so any series of characters, spaces and tabs showed as the same thing on every CRT terminal and the DECwriter followed that convention.
But then the microcompter came along, and then the word processors probably Wordstar, which took TAB to mean whatever the programmer(s) wanted it to mean, some odd predefined tabstop or four spaces or whatever This was in the word processor's own proprietary file format, which was almost forgivable, but it was surely not properly converted when the file was saved as ASCII. Nowadays even "straight text" programming editors let you tell it how far to move with the tab character. At least most can be configured to insert the appropriate number of spaces into the file instead of the tab, so it's possible to ... write Python with good formatting. No one uses tab to mean 8 spaces anymore anyway. Modern indenting is four, or maybe 3 or 2 spaces.
So really the thing has lost all usefulness, and causes more problems than it solves. I can see where it originally saved extra space characters, but source code size in memory or on a hard disk is no longer a problem, and version control systems do data compression anyway.
So I have Notepad++ set to insert spaces to get to the next four-space "tab stop" and I'm happy that my code will look the same in any text editor. But then in recent years I have this growing program I was splitting up into several source files, and I go back and look at the Make documentation for the first time in a few decades, and it REQUIRES a tab character ...
If I had a dollar for every "you can fix ThisEditor to strip trailing spaces" comment I could invent a time machine and pay whoever first wrote Make to have it accept "one or more tabs or spaces" for an indented line, and always ignore trailing spaces.
Is it necessary for Make to work in this way? If not why dont they change Make for such an agonizing problem?
Likely because it's a "legacy" thing and they're afraid to change it out of fear of somehow breaking something. There's no reason not to make Make more reasonable, it's not like it's part of any language spec, or part of Posix or anything, at least I don't think so.
:set list , in case you are using vim editor. Encountered it multiple times. Trivial yet good to know for anyone working with make files.
Good point. Thanks.
Does this happen with CMake?
I just have my editor (neovim) set up to both display whitspaces aswell as auto trim trailing spaces in any file I edit. I didn't know about this issue with make but that might be because I never had to encounter it
It’s not easy to encounter imho. How would one come into a situation where one doesn’t know what whitespace is used? o_O
damn, somebody has to rework the makefile parser
I dont understand where src and obj value came from that assign into SRC and OBJ
Those are just the names of the subdirectories that I'm using to build my project. SRC and OBJ are the variable names, the lowercase "src" and "obj" are just string literals.
@@JacobSorber i see, i thought src and obj are special string 😅
The only reason I don't code in C is because compiling it always feels like a can of worms, and at this point I have no patience to try to solve the issues... :(
EDIT: lol I just revisited a broken python script for compiling C that I made a while ago, and made it work. I am now able to compile C. To paraphrase a portuguese saying: when you don't have a dog, you hunt with a python. :D
Great!
This is why I try to use Taskfile instead of a Makefile if possible.
This reminds me of the aircraft disasters that resulted from loose screws.
:)
I don't understand. How long has Make existed for? Why does Make still have a whitespace issue.
yah i face the same in docker-compose file
surely someone has written a program or script to "lint" makefiles for things like this?
The truth is that for the most of time, build tools aren't even needed. You can compile just fine using shell scripts. I don't know why people love complicating things.
I have seen problems with whitespaces after \ escape, which was supposed to be escaping a the newline, but there it was actually escaping a whitespace.
It is a good practice to configure editors to display and optionally clean whitespace, potentially making use of plugins like editorconfig.
It is not uncommon for me to open a file and get mad of the carelessness with trailing whitespace, to which I usually respond with a :%s/\s\+$::g 😅
See whitespace characters in vim. :set list
Thanks.
Ah, that explains a lot..
Can you make a video for fasm?
Nice vid tho ;)
I'll add it to the list and see what I can do.
I just make vim remove whitespace at the end of every line if it exists when i save the file automatically
Reminds me of bashrc file. Alias and path issues and figured out it was just a white space issue. Frustrating
Is it only me or why is it that every single repository on github with Makefile can NEVER be built from source with make? Like, ever?
You should really start a subreddit or a discord server
"if you have hair" 😥😥
Teach us CMake!
You can toggle "render whitespace" on VSCode to see all spaces/tabs on the file, it is really useful to trace bugs like this.
Great video btw
Yes, you can. Thanks.
I had this bug once then promptly wen full on monke
make -r
turn off builtin rules then your debug isn't full of 1970s era version control rules.
I would be very happy to never hear the word 'makefile' again.
Invisible control character.
Sir plz start embbeded programming on c language create own header files create own function on c plz sir start that tutorial i am waiting for this tutorial quite while
If, by any chance, make was a Microsoft tool, hellfire would break loose. Now I'm reading excuses and workarounds. Like claiming the car is good, despite breaks, sometimes, don't work over 60mph, but if you slow down, it might. I understand that make si an old tool, but warship it in the museum, don't recommend it anymore.
The perfect Makefiles are the ones you make along the way
Love american humour.
And..good tips!
I should have known it earlier
got it right on first try lol because i had this problem
use vpath it better or -I in gcc
Why couldn't you just diff the two versions ? because the two files obviously mismatch !
Just vim or grep.
WHAT?
"... i know years of experience"
***proceeds to make rocket science out of white space***
isn't one of the first things you learn about make that it's white space sensitive
not POSIX compliant Makefile, REEEEEE
I just hope one day make stops existing
5:24 wow, how come you dont mention 'cat --vet' 😂😂
oh wait, it doesnt shows whitespaces, rather just the tabs and newlines
make and python, (almost) same shit with white-spaces
I feel like you are probably not a yaml kinda guy... whitespace dependence even more picky than Python
Yeah, I know. I do use YAML when it makes sense (just like I use python and make). But, their whitespace-based issues feel like unnecessary self-inflicted wounds.
I hate these tabs and these LFCR from microsofts textfiles .... grrrrrr
dos2unix is my friend and cat file.txt | tr -d "\t"
Personally I see this as a newbie issue. You shouldn't be leaving whitespace at the end of the line unless you mean to anyway.
Sure, but to be fair, I could say the same thing about seg faults, memory corruption, memory leaks, and just about any kind of programming mistake out there. Most everything is easy once you understand it.
@@JacobSorber True. Keep making the videos. I wish I had had videos like this back in the day.
First Viewer!
Nice.
Would cat -e Makefile work?