[리눅스 프로그래밍] IPC + MySQL을 이용한 텍스트 기반 머드게임 만들기

이것 역시 학교 과제로 만들었던 프로젝트입니다. IPC(Inter-Process Communication)을 이용하여 다중 접속이 가능한 머드 게임을 만드는 것이었는데요. IPC는 SystemV시절부터 있어왔던 프로세스간 통신 방법입니다.

* 시나리오
서기 2080년 지구의 지상은 인간들의 무분별한 전쟁과 자원 채취로 인간이 살 수 없는 환경이 되어버렸다. 이에 인간들은 우주를 개척하려고 하였으나 아직 인간이 우주에서 살아가기에는 아직 기술적인 문제가 많고 또한 정치적인 문제까지 겹쳐 우주발전이 지연되고 있는 상황이다. 하지만 뛰어난 중력 컨트롤 과학 기술을 이용하여 인간이 살기 힘들 정도로 오염된 지상을 떠나 하늘에서 거주하기 시작하였다. 하늘에는 부유하는 도시가 생겨났고 개인 비행선은 최고의 이동수단이 되었다. 당신은 이제 자신의 비행선을 가지고 무역, 전쟁 또는 도적질을 할 수 있다. 하지만 조심해야 한다. 인간이 하늘로 올라가는 것을 신에 대한 모독이라 여기는 광신교 집단이 무차별적인 공격을 감행하고 있다는 소문이 있다. 또한 환경오염에 따른 괴생물체가 자주 출몰하곤 한다.
당신의 앞날에 행운을 빈다.

위와 같이 나름 멋진 시나리오를 갖추고 멋진 방대한 규모의 설계서를 제출하였습니다. 하지만 역시나 시간상의 압박으로 제대로 구현하지 못하였습니다-_-; 기획의 20%정도만 완성…. 아무튼 결과적으로 A+받았으니 그것으로 만족해야 할것 같네요;;

사용자 삽입 이미지서버를 실행한 모습입니다.

사용자 삽입 이미지클라이언트를 실행하여 아이디와 비번을 입력하고 접속합니다. 계정 관리는 MySQL디비를 활용합니다.

사용자 삽입 이미지users명령어를 이용하여 접속한 사용자들의 리스트를 볼 수 있습니다.

사용자 삽입 이미지stat을 치면 현재 체력을 볼 수 있습니다.

사용자 삽입 이미지map을 치면 현재 위치와 향하고 있는 방향을 알 수 있습니다.

사용자 삽입 이미지특정 사용자에게 메시지를 전송할 수 있습니다.

사용자 삽입 이미지다른 사용자의 입장에서 본 화면입니다. 메시지가 도착했네요.

사용자 삽입 이미지모든 접속자에게 전체 메시지를 보냅니다.

사용자 삽입 이미지미리 구현된 맵을 이동해 다녀봅니다. 막힌 지역으로는 이동할 수가 없으며 다른 사용자를 만날 경우 메시지를 표시해 줍니다.

사용자 삽입 이미지접속을 끊었다가 재 접속하면 최종 로그아웃 했던 위치에서 다시 시작합니다. DB를 활용합니다.

기존적으로 맵의 구현은 다음과 같습니다. 0은 일반 지역 1은 구름이 있어 이동 불가능한 지역입니다.
[code]int Map =
{
{1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1},
{1,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,1},
{1,0,0,0,0,0,0,1,1,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,1},
{1,0,1,0,0,0,0,1,1,1,0,0,0,0,0,0,0,0,0,0,0,0,0,0,1},
{1,0,1,1,1,0,0,0,0,0,0,0,0,0,1,1,1,1,0,0,0,0,0,0,1},
{1,0,0,1,1,0,0,0,0,0,0,0,0,0,1,1,1,1,0,0,0,1,0,0,1},
{1,0,0,1,1,0,0,0,0,0,0,0,0,1,1,1,1,1,0,0,1,0,0,0,1},
{1,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,1,0,0,0,1},
{1,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,1,1,1,0,0,0,1},
{1,0,0,0,1,0,0,0,1,1,0,0,0,0,0,1,1,1,1,1,1,1,0,0,1},
{1,0,0,1,0,0,1,1,1,1,1,0,0,0,0,0,0,0,1,1,0,0,0,0,1},
{1,0,1,1,1,0,0,1,1,1,1,0,0,0,0,0,0,0,0,0,0,0,0,0,1},
{1,0,1,1,0,0,0,0,1,1,0,0,0,0,0,0,0,0,0,0,0,0,0,0,1},
{1,0,0,1,1,0,0,0,1,0,0,0,0,0,0,0,0,0,1,1,0,0,0,0,1},
{1,0,0,1,1,1,0,0,1,1,0,0,0,0,0,0,0,1,1,1,0,0,0,0,1},
{1,0,0,0,1,1,0,0,1,1,0,0,0,0,0,0,1,1,1,0,0,0,0,0,1},
{1,0,0,0,1,0,0,0,0,0,0,0,0,1,0,0,1,0,0,0,0,0,0,0,1},
{1,0,0,0,0,0,0,0,0,0,0,0,1,1,0,0,0,0,0,0,0,0,0,0,1},
{1,0,0,0,0,0,0,0,0,0,1,1,1,1,0,0,0,0,0,0,0,0,0,0,1},
{1,0,0,0,0,0,0,0,0,1,1,1,1,0,0,0,0,1,1,1,0,0,0,0,1},
{1,0,1,1,1,0,0,0,0,0,1,1,0,0,0,0,1,1,1,1,1,0,0,0,1},
{1,0,1,1,1,0,0,0,0,0,0,0,0,0,0,0,1,1,1,1,1,1,0,0,1},
{1,0,0,1,1,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,1},
{1,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,1},
{1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1}
};[/code]

MySQL 데이터 베이스 스키마는 다음과 같습니다. 다음의 테이블을 추가해 둔후에 common.h안의 DB서버 정보를 입력해 주시면 됩니다.

[code lang-sql]CREATE TABLE `USER` (                                 
 `USER_IDX` int(11) NOT NULL auto_increment,         
 `USER_ID` varchar(20) default NULL,                 
 `USER_PW` varchar(20) default NULL,                 
 `USER_NAME` varchar(20) default NULL,               
 `X` int(4) default NULL,                            
 `Y` int(4) default NULL,                            
 PRIMARY KEY  (`USER_IDX`)                           
)


CREATE TABLE `NPC` (                                  
 `NPC_IDX` int(11) NOT NULL auto_increment,          
 `NPC_NAME` varchar(20) default NULL,                
 `ATTACK_DMG` int(4) default NULL,                    // 공격 데미지
 `DEFENSE` int(4) default NULL,                       // 방어력
 `HEALTH` int(4) default NULL,                        // 체력 (공격받을시 데미지 계산 : 현재 체력 – (사용자 공격데미지[10 fix] – NPC방어력))
 PRIMARY KEY  (`NPC_IDX`)                            
)[/code]

컴파일의 경우에는 Makefile을 참고하시면 되며, MySQL 라이브러리 패스를 이곳에서 지정하시면 됩니다.

1364223203.zip