DISABLE THIS AD


Reply
 
Thread Tools
Old November 3, 2003, 13:12   #1
closms
Settler
 
Local Time: 02:04
Local Date: November 21, 2009
Join Date: Nov 2003
Posts: 29
Linux Port
I'm wondering is anyone else is trying to port this to linux.

I spent some time on it and I got some of the mapgen dll's to build. Specifically Crater.so, fault.so, geometric.so, Plasma1.so and Plasma2.so

The above was the easy stuff though. I guess that hard part will be replacing dx calls with sdl calls and mss calls with openal calls.

I noticed that there is a linux makefile for dbgen. So I guess at least someone at activision was thinking of linux. ( Maybe they're reading this post, and could contact me? ).

Anyways, I'm interested in getting this thing up and running under linux. So if anyone thinks they can help out, that would be great!

Mike

ps. If you want to get a hold of me, use msn messenger (closms@hotmail.com). Don't send email there, I won't get it.

Last edited by closms; November 3, 2003 at 15:25.
closms is offline   Reply With Quote
Old November 3, 2003, 15:23   #2
kaan
CTP2 Source Code Project
Prince
 
Local Time: 09:04
Local Date: November 21, 2009
Join Date: Mar 2001
Location: Aarhus
Posts: 333
id be glad to help but i have never tried to port an application to linux before, im just a happy user/programmer. but i figure it cant be too hard, just a long hard pull to get everything plugged in to the proper system calls.

kaan
kaan is offline   Reply With Quote
Old November 3, 2003, 16:00   #3
Solver
lifer
Civilization IV CreatorsAge of Nations TeamApolytoners Hall of FamePolyCast TeamBtS Tri-LeagueThe Courts of Candle'BreC4WDG Team Apolyton
Deity
 
Solver's Avatar
 
Local Time: 11:04
Local Date: November 21, 2009
Join Date: Sep 2000
Location: Latvia, Riga
Posts: 18,328
I believe that we should concentrate our efforts to work in some sort of a single fashion. Our priority now should be fixing the worst of game bugs, and adding sound on the Windows version.

Although for the future, Linux port is clearly a good idea.
__________________
Solver, WePlayCiv Co-Administrator
Contact: solver-at-weplayciv-dot-com
I can kill you whenever I please... but not today. - The Cigarette Smoking Man
Solver is offline   Reply With Quote
Old November 3, 2003, 16:22   #4
kaan
CTP2 Source Code Project
Prince
 
Local Time: 09:04
Local Date: November 21, 2009
Join Date: Mar 2001
Location: Aarhus
Posts: 333
these goals are not that different, porting ctp2 to linux is also making the sound work and fixing bugs, its just that if we do port this game to linux there will be a lot more ppl coming to help with the rest. Those ppl will for the most part be experienced in working in an open source community and we can really use that kind of ppl now.

kaan
kaan is offline   Reply With Quote
Old November 3, 2003, 16:23   #5
closms
Settler
 
Local Time: 02:04
Local Date: November 21, 2009
Join Date: Nov 2003
Posts: 29
Quote:
Originally posted by Solver
I believe that we should concentrate our efforts to work in some sort of a single fashion. Our priority now should be fixing the worst of game bugs, and adding sound on the Windows version.
A public CVS (www.cvshome.org) server would be a good way to coordinate all developer efforts. Does such a server exist?
closms is offline   Reply With Quote
Old November 3, 2003, 16:26   #6
Solver
lifer
Civilization IV CreatorsAge of Nations TeamApolytoners Hall of FamePolyCast TeamBtS Tri-LeagueThe Courts of Candle'BreC4WDG Team Apolyton
Deity
 
Solver's Avatar
 
Local Time: 11:04
Local Date: November 21, 2009
Join Date: Sep 2000
Location: Latvia, Riga
Posts: 18,328
As I posted in another thread, we may be prohibited from using a CVS.

Also, on Linux port, it's not open source. Usage of CtP2 source is limited by EULA.
__________________
Solver, WePlayCiv Co-Administrator
Contact: solver-at-weplayciv-dot-com
I can kill you whenever I please... but not today. - The Cigarette Smoking Man
Solver is offline   Reply With Quote
Old November 3, 2003, 16:29   #7
MrBaggins
CTP2 Source Code Project
King
 
MrBaggins's Avatar
 
Local Time: 09:04
Local Date: November 21, 2009
Join Date: May 1999
Posts: 1,528
The source code can, at this point, only be distributed from Apolyton, as far as I am aware, according to the code EULA. This would preclude a remote CVS, unless it was somehow implemented at Apolyton. I think ultimately some semi-manual system will be implemented.
MrBaggins is offline   Reply With Quote
Old November 3, 2003, 16:32   #8
kaan
CTP2 Source Code Project
Prince
 
Local Time: 09:04
Local Date: November 21, 2009
Join Date: Mar 2001
Location: Aarhus
Posts: 333
Quote:
Originally posted by Solver
As I posted in another thread, we may be prohibited from using a CVS.

Also, on Linux port, it's not open source. Usage of CtP2 source is limited by EULA.
i know that what we are dealing with here is not open source, but our way to work with the code (can you even say that?) is identical and thats why we could use ppl that has experience from that kind of projects.

i just read the licence again and you are right about the distributing part, thats a shame if that inhibits us from using a public CVS.

kaan

Last edited by kaan; November 3, 2003 at 16:56.
kaan is offline   Reply With Quote
Old November 3, 2003, 16:50   #9
closms
Settler
 
Local Time: 02:04
Local Date: November 21, 2009
Join Date: Nov 2003
Posts: 29
Quote:
Originally posted by Solver
As I posted in another thread, we may be prohibited from using a CVS.

Also, on Linux port, it's not open source. Usage of CtP2 source is limited by EULA.
What if Apolyton set up a pserver and only gave accounts to people who have accepted the EULA. That way CVS could still be used and we wouldn't be violating the code EULA.
closms is offline   Reply With Quote
Old November 3, 2003, 17:00   #10
kaan
CTP2 Source Code Project
Prince
 
Local Time: 09:04
Local Date: November 21, 2009
Join Date: Mar 2001
Location: Aarhus
Posts: 333
we could also make a source tree containing only the patch code, that way we can distribute all we want to.
the patch program in linux would be perfect, does anyone know if it has been ported to win32? it might be part of cygwin but i dont know.

kaan
kaan is offline   Reply With Quote
Old November 3, 2003, 18:00   #11
EzInKy
Settler
 
EzInKy's Avatar
 
Local Time: 05:04
Local Date: November 21, 2009
Join Date: Mar 2002
Location: Kentucky
Posts: 7
Since the code was written for DirectX 7 it may be possible to get it to compile against winelib.
EzInKy is offline   Reply With Quote
Old November 3, 2003, 18:11   #12
kaan
CTP2 Source Code Project
Prince
 
Local Time: 09:04
Local Date: November 21, 2009
Join Date: Mar 2001
Location: Aarhus
Posts: 333
winelib of course

you are a hero my friend
kaan is offline   Reply With Quote
Old November 3, 2003, 19:38   #13
Locutus
Apolytoners Hall of FameCiv4 SP Democracy GameCiv4 InterSite DG: Apolyton TeamBtS Tri-LeagueC4BtSDG TemplarsC4WDG Team ApolytonCivilization IV CreatorsCTP2 Source Code ProjectPolyCast Team
Deity
 
Locutus's Avatar
 
Local Time: 10:04
Local Date: November 21, 2009
Join Date: Nov 1999
Location: De Hel van Enschede
Posts: 11,631
As far as CVS and stuff goes, I'm working on that (seeing what's technically/legally possible), please give me some time...
__________________
Administrator of WePlayCiv, a brand-new Civ fansite that's all about community -- join us today!
Locutus is offline   Reply With Quote
Old November 4, 2003, 09:57   #14
J Bytheway
Call to Power PBEMCall to Power II Democracy GameCTP2 Source Code Project
Emperor
 
J Bytheway's Avatar
 
Local Time: 09:04
Local Date: November 21, 2009
Join Date: Jul 2001
Location: England
Posts: 3,825
We (those who have downloaded the code) all already have a copy of diff that came with the source code. I'm sure it will come in handy.
J Bytheway is offline   Reply With Quote
Old November 4, 2003, 14:26   #15
closms
Settler
 
Local Time: 02:04
Local Date: November 21, 2009
Join Date: Nov 2003
Posts: 29
PATCH
Hello All,

I've made a patch available to kick off the linux port. Contributions and criticism are welcome.

http://www.cs.ualberta.ca/~closson/ctp2/

Right now the work is pretty basic. Correcting case, and compiler warnings. Also VC++ has some quirks that aren't supported on g++. It should be pretty easy to contribute.

Mike
closms is offline   Reply With Quote
Old November 4, 2003, 16:19   #16
uppi
Settler
 
Local Time: 09:04
Local Date: November 21, 2009
Join Date: Oct 2003
Posts: 14
Good Job

3 comments from me right now:

1. in the Makefile:
Code:
-mkdir dll
-mkdir dll/map
should be replaced by
Code:
-mkdir -p dll
-mkdir -p dll/map
(It isnt serious, just suppresses the warnings if the directories already exist)

2. What byacc are you using? Mine wouldnt accept the -o option. I had to remove it and copy the files manually.

3. There should be a variable like WINE_INCLUDE_DIR (or something like that) in the Makefile, pointing to the include dir of the winelib, because then it would be easier to change the Path of the winelib include files.
uppi is offline   Reply With Quote
Old November 4, 2003, 18:58   #17
uppi
Settler
 
Local Time: 09:04
Local Date: November 21, 2009
Join Date: Oct 2003
Posts: 14
And they are really allowed to call this "C++ Code"? I cant believe the VC++ compiler is accepting this. The Header files are a real mess. To get this working declarations have to be taken from one file and put into another, because header files are needing declarations from each other...

Well i managed to correct some errors (especially the "enum"-Errors) but now i am stuck with structure (?) called MouseEventCallback. It is used as a type, but i cant find a declaration of it and so g++ complains. Anybody got an idea where the declaration is / how to solve that?

Last edited by uppi; November 4, 2003 at 20:20.
uppi is offline   Reply With Quote
Old November 4, 2003, 21:46   #18
closms
Settler
 
Local Time: 02:04
Local Date: November 21, 2009
Join Date: Nov 2003
Posts: 29
Quote:
Originally posted by uppi
And they are really allowed to call this "C++ Code"? I cant believe the VC++ compiler is accepting this. The Header files are a real mess. To get this working declarations have to be taken from one file and put into another, because header files are needing declarations from each other...

Well i managed to correct some errors (especially the "enum"-Errors) but now i am stuck with structure (?) called MouseEventCallback. It is used as a type, but i cant find a declaration of it and so g++ complains. Anybody got an idea where the declaration is / how to solve that?
I guess VC++ lets you typedef a function signature and then use it to declare function prototypes. MouseEventCallback is an example of this.

eg.

typedef void (*MouseEventCallback)( aui_MouseEvent *mouseData );

virtual MouseEventCallback PreChildrenCallback {}

The traditional way to do this is

virtual void PreChildrenCallback( aui_MouseEvent *mouseData ) {}

Have a look at ui/aui_common/aui_region.h line 354 of my patched version.

This is what is happening that causes the enum problems

header a.h
------------
#include "b.h"

enum a1 {
a1_a,
a1_b,
a1_c
};

class a2 {
b1_a var;
.....
};

--------------

header b.h
-------------
#include "a.h"

enum b1 {
b1_a,
b1_b,
b1_c
};

class b2 {
a1_a var;
.....
};
---------------

So basically there are circular dependencies. I think the easiest way to fix this is to place the #include "a.h" after the enum is declared.

GENDER and CIV_INDEX are two good examples of this.

Mike
closms is offline   Reply With Quote
Old November 5, 2003, 13:40   #19
uppi
Settler
 
Local Time: 09:04
Local Date: November 21, 2009
Join Date: Oct 2003
Posts: 14
thanks

Now I managed to compile all the files in ctp/ctp2_utils
uppi is offline   Reply With Quote
Old November 5, 2003, 22:08   #20
bfennema
Settler
 
Local Time: 01:04
Local Date: November 21, 2009
Join Date: Nov 2003
Posts: 1
I got the executable to build with SDL/SDL_mixer instead of mss32, and sound (at least the sfx) seem to work fine. The only thing I couldn't do a direct mapping of was cdrom volume. I couldn't find a way in SDL to adjust the cdrom volume.
bfennema is offline   Reply With Quote
Old November 5, 2003, 22:30   #21
Peter Triggs
CTP2 Source Code ProjectCivilization IV Creators
King
 
Local Time: 09:04
Local Date: November 21, 2009
Join Date: Jan 2000
Location: Gone Fishin, Canada
Posts: 1,059
Nice work

I don't know how the SDL audio subsystem works, but your efforts are much appreciated.
Peter Triggs is offline   Reply With Quote
Old November 5, 2003, 22:32   #22
MrBaggins
CTP2 Source Code Project
King
 
MrBaggins's Avatar
 
Local Time: 09:04
Local Date: November 21, 2009
Join Date: May 1999
Posts: 1,528
Its great... If we can get some linux people involved... well... the more the merrier.
MrBaggins is offline   Reply With Quote
Old November 6, 2003, 16:26   #23
closms
Settler
 
Local Time: 02:04
Local Date: November 21, 2009
Join Date: Nov 2003
Posts: 29
Quote:
Originally posted by bfennema
I got the executable to build with SDL/SDL_mixer instead of mss32, and sound (at least the sfx) seem to work fine. The only thing I couldn't do a direct mapping of was cdrom volume. I couldn't find a way in SDL to adjust the cdrom volume.
Great work! Yea, I'm surprised that more game companies don't use sdl or openal instead of mss.

Is this under windows or linux? If it's under linux then my hats off to you for fixing all the annoying compiler problems so quickly!

Mike
closms is offline   Reply With Quote
Old November 8, 2003, 14:00   #24
closms
Settler
 
Local Time: 02:04
Local Date: November 21, 2009
Join Date: Nov 2003
Posts: 29
Does anyone know how to get g++ to grok the following?

file: a.h
-----------------
#ifndef A_H
#define A_H

#include "b.h"

class a {
b m_b;
};
#else
class a;
#endif
-----------------
file: b.h
-----------------
#ifndef B_H
#define B_H

#include "a.h"

class b {
a m_a;
};

#else
class b;
#endif
-----------------
file: tmp.cc
-----------------
#include "a.h"
#include "b.h"

int main() {
a a_var;
return 0;
}
-----------------

Mike
closms is offline   Reply With Quote
Old November 9, 2003, 12:25   #25
kaan
CTP2 Source Code Project
Prince
 
Local Time: 09:04
Local Date: November 21, 2009
Join Date: Mar 2001
Location: Aarhus
Posts: 333
Quote:
Originally posted by bfennema
I got the executable to build with SDL/SDL_mixer instead of mss32, and sound (at least the sfx) seem to work fine. The only thing I couldn't do a direct mapping of was cdrom volume. I couldn't find a way in SDL to adjust the cdrom volume.
Could you please zip up the changed files and post them here?

kaan
kaan is offline   Reply With Quote
Old November 9, 2003, 13:45   #26
Leland
Prince
 
Local Time: 11:04
Local Date: November 21, 2009
Join Date: Jan 2000
Posts: 517
Quote:
Originally posted by closms
Does anyone know how to get g++ to grok the following?

(snip)
No c++ compiler should accept that piece of code. Basically class a contains class b, and class b contains class a, which leads to an infinite regress. Depending on what you really want to achieve with that piece of code, you could

1) replace m_a and m_b with pointers and use forward declarations instead of including the headers, or

2) declare a common base class for both of them which contains the data you want shared.
Leland is offline   Reply With Quote
Old November 9, 2003, 13:46   #27
Maajromax
Settler
 
Local Time: 04:04
Local Date: November 21, 2009
Join Date: May 2002
Posts: 8
Or, perhaps better, post a diff against the original source.

So long as it doesn't break anything, a linux-buildable source would be an excellent starting place for everyone else's modifications, as it's much more likely to remain portable/cross-platform.
Maajromax is offline   Reply With Quote
Old November 9, 2003, 18:47   #28
uppi
Settler
 
Local Time: 09:04
Local Date: November 21, 2009
Join Date: Oct 2003
Posts: 14
Quote:
Originally posted by Leland

No c++ compiler should accept that piece of code. Basically class a contains class b, and class b contains class a, which leads to an infinite regress. Depending on what you really want to achieve with that piece of code, you could

1) replace m_a and m_b with pointers and use forward declarations instead of including the headers, or

2) declare a common base class for both of them which contains the data you want shared.
Actually there were no circular dependencies in the classes itself, but in the header files containing the various enums. By putting these enums in a seperate header file this is (more or less) easily solved.
uppi is offline   Reply With Quote
Old November 11, 2003, 13:08   #29
Leland
Prince
 
Local Time: 11:04
Local Date: November 21, 2009
Join Date: Jan 2000
Posts: 517
Quote:
Originally posted by uppi

Actually there were no circular dependencies in the classes itself, but in the header files containing the various enums. By putting these enums in a seperate header file this is (more or less) easily solved.
Actually I was talking about closms' code.
Leland is offline   Reply With Quote
Old November 16, 2003, 18:09   #30
closms
Settler
 
Local Time: 02:04
Local Date: November 21, 2009
Join Date: Nov 2003
Posts: 29
robotcom
Does anyone know what the code in this subdir of for? I find a lot of duplicate headers in here. And including them has been nothing but trouble (im working on getting all the ui code to compile).
closms is offline   Reply With Quote
Reply

Bookmarks

Thread Tools

Posting Rules
You may not post new threads
You may not post replies
You may not post attachments
You may not edit your posts

BB code is On
Smilies are On
[IMG] code is On
HTML code is On

Forum Jump


All times are GMT -4. The time now is 05:04.


Design by Vjacheslav Trushkin, color scheme by ColorizeIt!.
Powered by vBulletin® Version 3.8.2
Copyright ©2000 - 2009, Jelsoft Enterprises Ltd.
Apolyton Civilization Site | Copyright © Robert Plomp and Jeroen Schweitzer