Console Applications
- 
@tomy Yea exactly like cmd on windows. That is the console for a windows platform. Real world console applications are things like utilities, servers, etc. Some you might know in windows are ipconfig,ping,net, etc.Those "extensions" are all applications in a posix environment. Linux/osx/android/etc. I can give you a real world example for the multi-UI approach... Recently I was contracted to write a program that handled packaging of files for distribution to embedded devices like credit card terminals, etc. We'll call it package manager. This package manager had a GUI where you could build the packages easily with drag and drop from the filesystem, etc. It handled all the devices types you could create the packages for, and generally was easy to use as GUIs tend to be. However, there was a build and automation team at this company who needed to make these packages as well. For them I provided the same functionality but in a CLI (command line interface AKA a console application). This allowed them to automate creating of packages with their ruby scripts. Also it allowed the SCM build management team to create packages as parts of the build for customers all from cmake and other automated build environments. Qmake could do it as well. So basically, GUIs save a lot of typing work, but require human interaction. CLIs you can pass the information in via a file or on the command line, however you want, and it's automated. So it can all be run as part of an automated thing. There are a lot of times where I prefer console apps to GUI ones. Most people who want to mess with files on their system would open a file manager (in windows Explorer), click around to browse to their files, etc. For me I prefer the console. I would open a terminal, cd to the directory I need, cp to copy files, mv to move, etc. I much prefer typing to a mouse. A mouse is slow, typing is very fast, especially if you know hot keys for everything. A good example of this.. let's say you wanted to know your IP address (in windows)... With a keyboard not even touching your mouse you could hit Window+R type cmd hit enter. Then type ipconfig /all<enter> and you're done. That's using the CLI. To do the same thing in the GUI, you have to click start, control panel, Network Settings, Right click your adapter, properties, double click TCP/IP v4, and finally you have your IP address... It would take me about 3 seconds with a keyboard and upwards of 15-20s with a mouse. And finally yes, most (all?) IDEs are just ways to wrap the underlying console tools. So Qt Creator uses mingw or visual studio as it's compiler, and gdb (or vs?) as it's debugger. Everything you do in Qt Creator can be done (very easily) without it. You can do it on the command line, or you can use other IDEs. As a die hard vim user I prefer VI compatible IDEs like slickedit or clion (those aren't free though). Creator has some basic vim support which is cool, as does visual studio. CLion is my favorite these days though. It doesn't have support for Qml at the moment which annoys me but I think when I get time I will write a Qml plugin for it, assuming they don't beat me to it. ;) A final example... in Qt Creator you would hit build, underneath here is what it would do with a hidden console: qmake mingw32-make -j4So you could do that on your own without the IDE if you wanted. This is more prevalent in osx or linux than in windows though. Windows command line stuff is annoying rather than helpful like it is in a posix environment. I agree that these console uses are very prevalent in mac os and linux and you have been on linux and it has made it that you prefer console to mouse clicks. 
 I think windows command line stuff is not very annoying (and you used it to demonstrate the ability of a cmd compared to mouse clicks in the IP example!)Lets teach me (!) using a CLI instead of the IDE in Qt Creator: 
 As shown above, I've created a console project (in the first post of the thread), then wrote a simple code in themain.cpp.
 Now in the IDE I can click on run (or ctrl+r) to see the result. Then it finishes. How to do these things (this process) using CLI without using the IDE?As an out of scope question: do you return the base of CMD (DOS OS) to Unix? 
- 
I agree that these console uses are very prevalent in mac os and linux and you have been on linux and it has made it that you prefer console to mouse clicks. 
 I think windows command line stuff is not very annoying (and you used it to demonstrate the ability of a cmd compared to mouse clicks in the IP example!)Lets teach me (!) using a CLI instead of the IDE in Qt Creator: 
 As shown above, I've created a console project (in the first post of the thread), then wrote a simple code in themain.cpp.
 Now in the IDE I can click on run (or ctrl+r) to see the result. Then it finishes. How to do these things (this process) using CLI without using the IDE?As an out of scope question: do you return the base of CMD (DOS OS) to Unix? @tomy "As an out of scope question: do you return the base of CMD (DOS OS) to Unix?" - what does it mean? What is base? Writing a simple CLI C++ app without IDE in a terminal (CMD): - Use an editor to write your cpp file (for example vim or what ever): vim myapp.cpp
- Then call the compiler: g++ -o myapp myapp.cpp
- Then start your app: ./myapp
 That's all for a simple app.
 In Qt creator you can see what it does if you press CTRL-R in "Compile Output" tab: it uses only CLI tools, like qmake, compiler (for example g++), linker,...
 Console apps are not only important on UNIX/Linux/MacOS but even on Windows. You need them for example to write scripts, build software,... 
- 
I agree that these console uses are very prevalent in mac os and linux and you have been on linux and it has made it that you prefer console to mouse clicks. 
 I think windows command line stuff is not very annoying (and you used it to demonstrate the ability of a cmd compared to mouse clicks in the IP example!)Lets teach me (!) using a CLI instead of the IDE in Qt Creator: 
 As shown above, I've created a console project (in the first post of the thread), then wrote a simple code in themain.cpp.
 Now in the IDE I can click on run (or ctrl+r) to see the result. Then it finishes. How to do these things (this process) using CLI without using the IDE?As an out of scope question: do you return the base of CMD (DOS OS) to Unix? @tomy @jsulm's example is perfect for linux but since I know you don't know linux yet and are using windows I'll give you the same thing for windows: Launch a cmd and do the following: > mkdir test > cd test create a main.cpp with somthing like: #include <iostream> using namespace std; int main() { cout << "hello world" << endl; return 0; } > qmake -project > qmake > mingw32-make > test.exeThis assumes you have /path/to/qt/bin in your path variable in order to use and access qmake. It also assumes you have mingw32 compiler installed. If not substitute compilation command mingw32-makefor whatever compiler you have.This is a great example of where linux is easier than windows on a command line (from our other thread). There is no real additional setup in linux, all the stuff @jsulm wrote works right out of the box. Edit: Explaining some of the commands -- qmake -projectWill create you a test.pro file. This is only done once to bootstrap your project file. After that you modify that .pro file to add the things you need.qmakeevaluates the project file and creates a makefile for you.mingw32-makeinvokes the make program for the mingw compiler. This will execute the Makefile that was generated when you ran qmake and build your application using mingw32-g++, and other pieces it needs to compile and link.
- 
@tomy 
 Well do you see .o file ? Maybe there is a build folder one level up?
 If not, then show the log (text) you get from running mingw32-make (step)
 Maybe there is compile or link error as that would do that no .exe is created.Ah, sorry. Its in the release folder  
- 
@tomy 
 Well do you see .o file ? Maybe there is a build folder one level up?
 If not, then show the log (text) you get from running mingw32-make (step)
 Maybe there is compile or link error as that would do that no .exe is created.Ah, sorry. Its in the release folder  Oops sorry I forget that in windows things like Release/ and Debug/ folders. :) 
- 
Oops sorry I forget that in windows things like Release/ and Debug/ folders. :) @ambershark 
 Well i had to follow the sample and see. Was not sure what would really happen :)
- 
@ambershark 
 Well i had to follow the sample and see. Was not sure what would really happen :)@mrjj Lol. I'm glad it actually worked since I just typed that out without testing anything. And I don't use windows much so I could easily have messed it up. :) 
- 
Look, I did these: 
 Creating a C++ file named "main" with a simple code in it, in the "test" folder.
 Then, found and ran all three commands (qmake -project, qmake, mingw32-make).
 And the result as shown above (with no ".exe" file in the "test" folder.
 I CMD:
  
- 
Look, I did these: 
 Creating a C++ file named "main" with a simple code in it, in the "test" folder.
 Then, found and ran all three commands (qmake -project, qmake, mingw32-make).
 And the result as shown above (with no ".exe" file in the "test" folder.
 I CMD:
  
- 
Look, I did these: 
 Creating a C++ file named "main" with a simple code in it, in the "test" folder.
 Then, found and ran all three commands (qmake -project, qmake, mingw32-make).
 And the result as shown above (with no ".exe" file in the "test" folder.
 I CMD:
  
- 
Hi 
 An alternative to fiddling with path is to run the
 c:\Qt\5.8\mingw53_32\bin\qtenv2.bat
 in the cmd before trying to compile.
- 
Hi 
 An alternative to fiddling with path is to run the
 c:\Qt\5.8\mingw53_32\bin\qtenv2.bat
 in the cmd before trying to compile.Hi 
 An alternative to fiddling with path is to run the
 c:\Qt\5.8\mingw53_32\bin\qtenv2.bat
 in the cmd before trying to compile.Hi, 
 "The system cannot find the path specified."
 Anyway, it's not that important and we can leave it out because it's not my purpose to be familiar with running files from CMd, now. Maybe when needed.
 (I liked to test that simple example this way but, the testing may not be so easy) Thanks.
- 
Hi 
 An alternative to fiddling with path is to run the
 c:\Qt\5.8\mingw53_32\bin\qtenv2.bat
 in the cmd before trying to compile.Hi, 
 "The system cannot find the path specified."
 Anyway, it's not that important and we can leave it out because it's not my purpose to be familiar with running files from CMd, now. Maybe when needed.
 (I liked to test that simple example this way but, the testing may not be so easy) Thanks.
- 
Yes, I did it and I think the system is set now and ready for the next tests. You can look at this: 
  
 "text.exe" exists but nothing is shown after test.exe in CMD.Update: 
 After re-opening the CMD and testing the .exe:
  @tomy 
 what code you write in test?
 


