These instructions assume you have a computer with Linux and Windows already installed, and a filesystem that's visible to both. My machine, for example, dual-boots Ubuntu 10.04 LTS and Windows 7, with a shared data partition. These instructions also assume you have Visual Studio 2010. If you don't, you can get it from the Engineering school's MSDNAA program, or through Dreamspark.
ACE setup is easier on the CEC machines since it's already built. Instructions that you should skip for CEC machines are highlighted in light blue.
Part A: Build and Configure ACE on Linux (one-time setup)
- Download ACE, version 6.0.1 (latest BFO micro release), tar+bzip2 format, from http://download.dre.vanderbilt.edu/.
- Follow the steps here to set up and build ACE. You can skip steps 5, 8, and 9, since we're not installing it.
- Add the ACE_ROOT and LD_LIBRARY_PATH environment variables to your .bashrc or .cshrc. See #1 here for an example of how to go about this.
Part B: Build and Configure ACE on Windows (one-time setup)
- Download ACE, version 6.0.1 (latest BFO micro release), zip format, from http://download.dre.vanderbilt.edu/.
- Follow the steps here to set up and build ACE using Visual Studio 2010. Steps 3, 6, 7, and 8 are skippable. The build can take a while (half an hour for me).
- If you haven't already, add ACE_ROOT\lib to your Windows PATH variable. On the CEC machines ACE_ROOT\lib is "\\warehouse.cec.wustl.edu\home\cec\class\cse532\ACE_wrappers_win\lib".
- Tell Visual Studio where to find ACE header files and libraries:- Open Visual Studio 2010. If this is the first time the program's been used, choose the Visual C++ development environment if a dialog pops up.
- Go to File -> New -> Project...
- Choose Visual C++ Win32 Console Application and enter in a dummy name. (We'll delete the project later, so it doesn't matter what the name is.) Click OK, then Finish.
- Visual Studio has now created a dummy project for you. Go to View -> Property Manager. The Property Manager will probably appear in the upper right or upper left.
- Click on the small arrow to the left of the project name in the Property Manager to expand it. The Property Manager should now look something like this:
 
- Click on the small arrow to the left of "Debug | Win32" in the Property Manager to expand it.
- Double-click on "Microsoft.Cpp.Win32.user".
- Under "Common Properties", click on "VC++ Directories".
- In "Include Directories", add the full path for ACE_ROOT at the end (use a semicolon as a separator if needed). For example, on my machine ACE_ROOT is "C:\Program Files\ACE\ACE-6.0.1\ACE_wrappers". On the CEC machines ACE_ROOT is "\\warehouse.cec.wustl.edu\home\cec\class\cse532\ACE_wrappers_win".
- In "Library Directories", add the full path for ACE_ROOT\lib at the end (use a semicolon as a separator if needed). For example, on my machine ACE_ROOT\lib is "C:\Program Files\ACE\ACE-6.0.1\ACE_wrappers\lib". On the CEC machines ACE_ROOT\lib is "\\warehouse.cec.wustl.edu\home\cec\class\cse532\ACE_wrappers_win\lib". Click OK.
- Close Visual Studio 2010. If you get a prompt that says "One or more inherited user property sheets have not been saved. Save them now?", click Yes. Delete the dummy project. (If you don't know where the dummy project is, it's probably at Documents\Visual Studio 2010\Projects.)
 
Part C: Add code and set up file structure
Part C and after are setup on the project level. Follow these instructions for every lab/studio/project that you want across both OSes and IDEs.- Create a folder for your lab/studio/project in the shared filesystem. In this document, the folder will be named Studio1.
- Create a srcfolder underneath the newly created project folder.
- Create ServerandClientfolders underneath the newly createdsrcfolder.
- Put server.cpp in the Serverfolder and client.cpp in theClientfolder.
Part D: Project setup on Windows
- Open Visual Studio 2010.
- Go to File -> New -> Project...
- Choose Visual C++ Win32 Console Application. Enter Clientfor the Name. Type in a more descriptive name for the Solution Name. In this document, it will beWindowsStudio1.
- For the location, select the upper-level folder for your lab/studio/project (Studio1in this example). Click OK.
- Click Next, then check Empty project. Click Finish.
- Go to View -> Solution Explorer. The Solution Explorer will probably appear in the upper right or upper left.
- In the Solution Explorer, right-click on Client, then go to Add -> Existing Item...
- Navigate to the src\Clientdirectory and selectclient.cpp. Click Add.
- Go to Project -> Properties. In the dialog that opens, go to the Configuration dropdown (in the upper left) and select "All Configurations".
- Go to Configuration Properties -> Linker -> Input.
- In the Additional Dependenciesfield, addace.libto the end (use semicolons to separate if necessary). Click OK.
- Go to File -> Add -> New Project...
- Enter Serverfor the name, then click OK.
- Click Next, then check Empty project. Click Finish.
- In the Solution Explorer, right-click on Server, then go to Add -> Existing Item...
- Navigate to the src\Serverdirectory and selectserver.cpp. Click Add.
- Go to Project -> Properties. In the dialog that opens, go to the Configuration dropdown (in the upper left) and select "All Configurations".
- Go to Configuration Properties -> Linker -> Input.
- In the Additional Dependenciesfield, addace.libto the end (use semicolons to separate if necessary). Click OK.
- You're ready to build! Select Build -> Rebuild Solution. Your executables will be at WindowsStudio1\Debug.
Part E: Project setup on Linux
- Create a directory for Linux-related project stuff underneath Studio1, for exampleLinuxStudio1.
- Download the course Makefile into the LinuxStudio1directory.
- For CMPL_SRCS1, changeclient.cppto../src/Client/client.cpp.
- For CMPL_SRCS2, changeserver.cppto../src/Server/server.cpp.
- Change line 78 from
 INCFLAGS = -I/home/cec/class/cse532/ACE_wrappers
 to
 INCFLAGS = -I$(ACE_ROOT)
- Change line 83 from
 LIBLOCFLAGS = -L/home/cec/class/cse532/ACE_wrappers/ace -L./
 to
 LIBLOCFLAGS = -L$(ACE_ROOT)/ace -L./
- Save and close the Makefile.
- You're ready to build! Run makein theLinuxStudio1directory. Your executables will be in the same directory (LinuxStudio1).
Random stuff
- For the most part, you can use the same code for both Windows and Linux. However, if you run into a situation where you need different code for each, use #ifdefs. On Windows,Win32has already been#defined, and on Linux, you can uselinux. For example:
 #ifdef WIN32
 printf("%s", "Running on Windows\n");
 #endif /* WIN32 */
 #ifdef linux
 printf("%s", "Running on Linux\n");
 #endif /* linux */
- At some point you might want to share code between client and server. Put the shared code in a new Sharedfolder undersrc. In Visual Studio, use Add -> Existing Item... to add each shared file to both projects. Similarly, for g++, modifyCMPL_SRCS1,CMPL_SRCS2,HEADER_FILES1, andHEADER_FILES2so all shared files are compiled into both targets.
Differences between ACE on Windows vs. Linux
ACE should work with the same code for both Windows and Linux, but sometimes this isn't the case. We'll try to post such differences here when we find them.- In the client code, ACE_INET_Addr server(SERVER_PORT);works in Linux but not in Windows. UseACE_INET_Addr server(SERVER_PORT, "127.0.0.1");instead.

 
No comments:
Post a Comment