'Programming'에 해당되는 글 91건

  1. 2006.07.18 Glade! 리눅스 GUI 프로그래밍 툴
  2. 2006.07.18 TCP/IP 추가 and UDP /IP
  3. 2006.07.15 소켓 프로그래밍 part 2~4 TCP/IP 4
  4. 2006.07.06 열혈강의 TCP/Ip Socket Programming --Part 1 1
  5. 2006.06.25 Beginning Linux Programming Part6-Curses 2

Glade! 리눅스 GUI 프로그래밍 툴

제 리눅스 책뒤에 Gtk+가 설명이 있길래..

(읽기만 했지 머가 먼지 아직도 모름........)

쭉보고 있다가... M$ Windows 의 VB처럼..  윈도우 화면(비베식으로 폼) 을 마우스 클릭/드래그

해서 컨트롤을 올리듯이.. 하는게 리눅스에는 없을까... (이 뻔한걸 일일이 코딩하긴 그렇고..)

하고서 구글링 and MSN을 이용해서 알아본 결과 Glade라는 툴을 알게 되었죠..

사실.. 처음 무지 당황했습니다.. 속성 설정하는 부분도 있고 화려할거 같았지만..

달랑 메뉴 5개 툴바 5개의 썰렁한 화면.........;;; 그리고 팔렛트...

처음엔 정말.. 새파일 열기 해도.. 아무것도 안뜨는겁니다 폼같은거라도 떠야 뭘 잡아 끌든 말든 할텐데..

팔렛트에서 겨우 윈도우라는 것을 누르니깐 폼이 뜨더라는(새파일 하면 바로 나올줄 알았는데 아니더군요)

일단 윈도우(폼)를 하나 만들고 팔렛트(VB식으로 컨트롤모음)에 요소들을 클릭해서 비베처럼 끌었습니다..

그런데.. 이번엔 비베처럼 아예 끌리지도 않는겁니다.. 아 이것땜에 몇일동안 처박아 두었는데...

오늘에서야 알았는데.."고정된 위치"라는 컨트롤을 사용하니깐 비베처럼 컨트롤을 끌수가 있겠더군요..!

또 하나 문제점이 발생했습니다.. 속성 설정하는게 또 뭔지 몰라서.. 메뉴 뒤저보니깐 속성창이라는게

하나 있네요.. 그걸 뛰우고 컨트롤? 클릭 하니깐 속성이 쫙 보이는... 흠.

그래서 시험삼아서 방금 이녀석으로 Hello World~  예제를 작성해 보았습니다

하하.. 버튼도 하나 만들어서 클릭 하면 윈도(폼) 이 자동으로 꺼지게~ 말이죠..

버튼 클릭해서 꺼지게 할려면 Gtk 시그널,핸들 을 알아야 하더군요...

전 몰라서 그냥 보이는데로 이리리 찍었습니다만..

시그널은 그 객체가 어떻게 반응을 받는가? 핸들은 무었을(시그널에 받은것에) 실행시킬까? 이런거 같네요

앞에서도 말했지만.. 정말 모릅니다.. 대충 찍었을뿐 ..

객체:button1 에 대해서 속성의 시그널 탭에--> signal:click handle:gtk_main_quit

(아 글구 꼭 저장을 해야 하더군요 .........)

이렇게 만들어 놓으면 button1을 클릭하면 프로그램이 종료 되더군요  아신기...하다~

이부분은 뭔가 비베와 비슷한부분? 인거 같네요..흠..(설마 이것도 객체지향인가 아 몰겟네.;;)

아 그리고 파일을 제공해서 빌드하면 자동으로 컴파일 할수 있는 상태로 만들어 주는 좋은 기능도 있네요.

autogen.sh 라는 스크립트를 이용하면 되네요.. 그리고 make... src디렉토리에 들어가면

제가 만든 프로그램이 나오네요 흐흐 실행해 볼가나..


저런 허접한 플그램 하나가 나옵니다.. 종료 버튼을 누르면 프로그램 종료~

(소켓해야하는데.. 왜 내가 이걸 하고 있을까;;;;;;;;;)

'Programming > GTK+' 카테고리의 다른 글

vte를 이용한 간단한 터미널  (2) 2007.01.14
libglade 컴파일법  (1) 2006.12.14
TODAY.... 삽질 DAY  (6) 2006.08.09
(초보) gtk 작성팁  (10) 2006.08.04
GTK_TEXT 에러..해결책  (4) 2006.07.30

TCP/IP 추가 and UDP /IP

Iterative 서버의 구현

while(1)
{
   client_fd=accept(&ser_sock,(struct sockaddr *)&client_addr,&client_addr_size);
         //에러 처리는 알아서 하자 귀차너//
   write(client_fd,SendMessage,sizeof(SendMessage)):
   close(client_fd);
} //아라.. 다시 보니깐 read 안썻네..

내 개인적인 생각이지만 다른거라면 while을 돌려서 쉬지 않게 메세지를 받게 하는 기능 정도만
추가된거 같다

음 근데 왜 accept함수를 while 문 안에 넣느냐 하면.. 아니 설명할 필요도 없나..
뭐 한번더 기억을 상기시켜 보자면은.. accept함수가 메세지를 입력 받는 함수이다(뭐라하는건지 쿨럭;)
라서 이다 ,;;

그림으로(?) 그려(?) 보았다 ....

socket() -> bind() ->listen() -> accept() -> file in/out -> close(client) ->close(server) ->END
                                                             |__________________________|
                                                                             while(1)

(책에서는 서버를 닫아주지 않았다... 끝날때 알아서 종료 되니깐 귀찮아서 안한거 같다....)

다른게 있다면 저~기 While 문을 썻다는거 뿐!


Plus! Packet

서버랑 클라이언트랑 메세지를 전달할때(아래서 부턴 패킷으로 부름) 크기가 정해져서 수신/전송이
되는게 아니다(라고 한다)
그래서 클라이언트일경우 쓴만큼 읽어 들여야 한다..

뭐어 대충 구조는 다음과 같다

1.write call해서 일단 쓴다..write함수의 리턴값을 저장하고서(이값이 read시 Max값이 되겠죠?)
wr=write(~);

2.반복문을 돌린다(while이든 for이든.. ) ex>for(i=0~

3. 반복문 안에 read함수를 넣고 리턴값을 받는다(이 리턴값은 read한 크기입니다) 에러처리를 하고 싶으면 한다 ex> rd=read(~);

4.i값이랑 read함수에서 받은 리턴값이랑 합산애서 i에 대입 ...i+=rd

5 증가값은 적지마시고 최대 Max값이 i 값보다 작을때까지 반복

이거 했갈릴테니깐 코드로 작성하믄

wr=write(sockfd,buf,strlen(buf)):

for(i=0;i<wr;)
{
   rd=read(sockid,&buf[i],wr-i);//에러 작성문은 알아서 만듭시당..
   i+=rd;
}
-------------------아놔... 제가 만들어 놓고서 뭐라고 적어논건지 모르겠어요----------------------

UDP? User Datagram Protocol 이랍니다.

데이터의 경계가 있기때문에(빼먹었는데 TCP에는 없습니다)클라이언트에서 질의를 3번하면
서버에서 응답을 3번해야한다는겁니다(그런거 같았;;)

그리고 TCP와는 달리 2개가 서로 연결되어서 통신하는게 아니기 때문에.. 간단하고 속도가 빠릅니다.

다음은 UDP 프로그램의 기본적 구조

server:구조체선언->구조체의 값 집어넣기->bind->입/출력.반복->소켓 닫음
(listen,accept함수가 없습니다)

client:구조체 선언->구조체에 값 집어넣기->파일 입출력(반복)->소켓 닫기
(connect 함수를 안써도 됩니다(때에 따라서))

동영상 스트리밍 서비스 같은데 많이 사용한다고 하더군요..빠른속도로 보내야 하니까요.. 대신 데이터

손실를이 높으니까 파일전송같은덴 알맞지가 않겠네요

뭐 암튼 TCP와는 다르게 파이프처럼 서로 연결된게 아니고 보내고 끝이라는 겁니다.

그렇기 때문에 보내고 받는함수를 read,write하지 말고 특수한 함수를 사용해야 한다네요

int sendto
(int sock,const void *meg,int len,unsigned flags,const struct sockaddr * addr,int addrlen);
sock:socket함수의 리턴값
meg:전송할 데이터를 저장하는 버퍼를 가르키는 포인터(이 포인터가 가르키는 곳으로 부터 데이터전송시작)
len,meg의 포인터가 가진 기점으로부터 몇바이트를 보낼것인가?(sizeof~)
flags:옵션,일반적으로 0을 넣어줌 자세한건 man페이지 참조
addr:앞에서 절라 써먹던 그 구조체
addrlen:앞에서 절라 써먹던 그 구조체의 크기

int recvform(int sock,int *buf,int len,unsigned flags,struct sockaddr * addr,int *addrlen);
sock:이건 정말 말하기 지겹다
buf:받은 데이터를 저장할곳을 가르키는 포인터
len:수신할수 있는 최대 바이트 어지간하면 buf값을 넘지 않도록 주의 한다
flags:전과 상등
addr:주소 정보 구조체 변수의 포인터를 인자로 넘김,다 완료되면 데이터를 전송한 호스트의 정보가 이
구조체에 저장되게 된다
addrlen:addr포인터의 크기를 가진 변수의 주소를 넘긴다

포트정보는 sendto 쓸때 같이 보내진다고 합니다

Plus! Connect 함수 사용
이 함수를 사용하면 일단 커널과 소켓간에 연결을 유지하면서 통신할수 있습니다.
(걍 TCP/IP 쓸때처럼 Connect함수를 while돌리기 전에 써주면 끝입니다)
그래서 속도향상을 꽤할수 있고.. 미리 정보를 전달해 주기때문에.. sendto,recvform 함수를 쓰지
않고서 read,write같은 함수를 입출력을 해도 된다고 하네요..

소켓 프로그래밍 part 2~4 TCP/IP

TCP/IP 소켓 프로그램의 기본적 예제

                     대략적 구조
Server ------------------------------Pipe-------------------------------------Client

socket 함수                                                                                       socket 함수
      |                                                                                                     |
bind 함수                                                                                          Connect 함수
      |                                                                                                     |
listen 함수                                                                                               |
      |                                                                                                     |
accept 함수                                                                                               |
      |                                                                                                     |
read,write                                                                                          read,write
send,recv함수                                                                                     send,recv함수
      |                                                                                                      | 
  소켓닫기                                                                                            소켓닫기


세부사항

<SERVER>

0> 해더파일을 삽입한다
#include<stdio.h> printf();
#include<stdlib.h> exit();
#include<string.h> memset();
#include<arpa/inet.h> socket();.......
#include<sys/types.h>      ''
#include<sys/socket.h>    ''


1>sockaddr_in 구조체를 선언한다...
ex>struct sockaddr_in server; (타입케스팅 할땐 struct sockaddr *)


2>struct 구조체 안의 변수에 값들을 채워준다,

bind등의 함수가 이 구조체의 값을 사용한다

sockaddr_in 구조체의 내부 변수들은 다음과 같이 설정해 준다

ex>
memset(&server,0,sizeof(server)); //구조체 할당하기전에 먼저 초기화
server.sin_family=AF_INET;    //IP의 성격 설정 대부분 ip4를 사용하므로 이렇게 설정
server.sin_port=htons(atoi(argv[1])); //host->Network (type short)
server.sin_addr.s_addr=htonl(INADDR_ANY); //host -> Network (type long) 일단 그냥 외우자

INADDR_ANY는 현재 자신의 IP주소를 말한다 지금 설명하는 프로그램은 서버이므로 자기 자신의
IP를 저장하고 있어야 한다

 
3>소켓을 만들어 준다

(listen함수에서 만들어진 큐을 제어하는 소켓이다 클라이언트와 연결되 작업하는그런 소켓이
아님을 명심하자)

       if((sockid=socket(AF_INET,SOCK_STREAM,0))==-1){
               perror("Socket Created ERROR");
               exit(1);
               }

아래는  man 페이지 수정/추가>

소켓은 지시된 통신 semantics를 지정하는 type 을 갖는다.  현재 정의된 타입은 다음과 같다:

      SOCK_DGRAM  <UDP>
             데이타그램 지원

      SOCK_STREAM    레코드 경계를 보호하진 않는다.  스트림 소켓은 모든 데이타가 그것으로  송수신 되기전에 접속 상태이어야한다.  <TCP/IP>
 
에러가 생겼을때 socket함수는 -1을 리턴 한다는걸 알수있다..
아래껏도 대부분 그렇다

4>bind 함수를 만들어 준다,각 주소로 연결하는 함수


       if(bind(sockid,(struct sockaddr *)&server,sizeof(server))==-1){
               perror("Socket Bind ERROR");
               exit(1);
       }

bind(소켓 파일디스크립터,sockaddr_in 구조체 주소
(꼭 타입 케스팅 할것!), 구조체의 크기);

여기서 소켓 파일 디스크립터란(또는 id?) 그리고 타입케스팅 할때 _in 빼자

5>대기열 생성

       if(listen(sockid,5)==-1){
               perror("Listen ERROR");
               exit(1);
       }

간단한 함수...
listen(소켓 id,대기 큐 갯수);
대기열을 왜 만드냐하면... 클라이언트가 한번에 여러개 접속할수 있으니까...
막 일려올때 순서를 정해서 일을 처리하기 위해서*/

6>연결 허용 accept함수

aceept함수는 크기를 줄때 주소로 주어야 한다
또 이함수는 새로운 소켓 id을 반환한다..

추가> 아까 만든 소켓을 대기큐를 제어하는데 쓰이는 소켓
이번에 만들어진 소켓이 정말 데이터를 처리한다*/

       faccept=sizeof(client);//주소 때문에 이렇게 함

               if((sockid2=accept(sockid,(struct sockaddr *)&client,&faccept))==-1){
                       perror("Aceept ERROR");
                       exit(1);
               }

accept함수의 리턴값이 바로 accept함수가 만들어준 새로운 소켓의 파일 디스크립터이다

7>나머지는 파일 입출력과 같다..

이 파일 디스크립터로 네트워크의 호스트에 연결된것이다 이 리턴된 파일 디스크립터 로 일반 표준 입출력
처럼 사용하면 된다(파이프를 연상하면 그나마 비슷할까)*/

       while(1)
       {
               read(sockid2,buf,100);
               printf("%s",buf);
               write(sockid2,buf,100);
       }

8>소켓을 닫는것을 일반 파일과 같게 적용되기도 한다
               close(sockid2);

절대 강조! (나에게 쓰는 메세지)
리턴값 처리해줘야 하는 함수는 socket(),accept() 함수 밖에 없다!!
(이상한거 리턴받아 쓰지 말자!!!!!!!!)

<Client>
(여기서 숫자는 서버의 단계 숫자)

일단 0~3까지의 순서는 SERVER와 같다
4~6의 과정은 쓰지 않는다
그러므로 생략 중간에 Connect함수쓰는거 빼면
7~8번째도 같다

이번엔 귀찮으니깐 Connect함수만 쓰도록 한다

if(connect(sockid,(struct sockaddr *)&server,sizeof(server))==-1){
    perror("Connect ERROR");
      exit(1);
}
뭐.. 설명이 필어 없을듯 하다 인자는 Bind함수랑 비슷하다(같은건가?)
서버와 연결을 할때 쓰는 함수다

7>
단 read,write쓸때
read 하면 클라이언트에서 받을거고
write하면 클라이언트에서 메세지를 보낸다
라는 약간의 차이가 있다
파일 디스크립터(클라이언트 에게 보넬 입출력 fd) 는 소켓을 생성한 파일 디스크립터에다가
read,write하면 된다

8> 번에 대해서는 뭐 당연하다고 생각하는데로 생각하면 된다

서버와 연결을 할때 쓰는 함수다  자세한건 Manpage~

열혈강의 TCP/Ip Socket Programming --Part 1

간단하게 정의
(클라이언트, 서버는 네트워크에 연결되어 있다고 가정)

클라이언트:정보를 보내는 프로그램(요청)
서버:정보를 받는 프로그램(수락)
*서버와 클라이언트는 소켓으로 연결을 한다

서버 프로그래밍의 예시

--전화                                               소켓                                           관련 함수
전화 사기                                    소켓 생성하기                                      (socket 함수)
전화 번호 얻기                            아이피 주소 얻어오기                                  (bind 함수)
전화 케이블에 연결하기                    신호 요청 대기                                      (listen 함수)     
전화 걸기                                       연결수락                                           (accept 함수)        

클라이언트 프로그래밍의 예시

--전화                                               소켓                                           관련 함수
전화 사기                                    소켓 생성하기                                     (socket 함수)
연결 요청                                    소켓 연결하기                                      (connect함수)
         
TCP  트랜스미션 컨트롤 프로토콜 :말그대로 "제어"한다 IP라는거 자체가 데이터를 전달하는게 정확성이
없다 쉽게 말해서 보내주긴 보내주는데 제 주소에 보내지던 말던은 상관을 안한다는 얘기..
그리하여 그런 상황을 미연에 방지하기 위해서 데이터를 송/수신 할때마다 제대로 도착했는지를 확인하는
프로토콜 이라고 말하면 대충 되려나...

UDP 유저데이터그램 프로토콜: 이녀석은 확인 같은거 안하고 걍 보내고 끝. 그래서 속도가 빠르다고 한다나

포트:각각의 프로세스가 이 포트와 연결되 있고(물론 네트워크와 관련된 프로세스들)여기서 각 네트워크
에서 오는 메세지를 받는곳(또는 보내던가).. 뭐 비교하자면

라우터:각각의 호스트(or 라우터)
들을 연결 한다  네트워크 A에서 네트워크 B로 데이터가 이동할려면 반드시  각
네트워크를 관리하는 라우터 끼리 연결이 되어야 한다
HostA->RouterA->RouterD->RouterE->RouterF....->RouterB->HostB
------------------------                                                                   ------------------------
Network A                                                                                    NetworkB


#include<sys/types.h>
#include<sys/socket.h>

sockfd=int socket(int domain,int type,int protocol);
int bind(int sockfd,struct sockaddr *myaddr,int addrlen);
int listen(int sockfd,int backlog);
sockfd2=int accept(int sockfd,struct sockaddr *addr,int *addrlen);
int connect(int sockfg,struct sockaddr *serv_addr,int addrlen);

//구조체 설명은 나중에 한다나 뭐라나..

다음 1-3 파트는 생략. 파일 입출력이므로 ,,,PASS
파트 1은 별루 한것도 없이 그냥 끝~~~~

--------추가 _t 자료형(size_t,time_t,key_t등)-----------
에 대해서는 컴퓨터 비트가 바뀌면서 저장크기(ex int.. 16bit==2 32bit==4)
의차이가 나게 되므로 이런 경우를 줄이기 없애기 위해서 해더파일에서 정의 해 놓은 모양임

'Programming > Networking' 카테고리의 다른 글

gethostbyname 의 세그멘테이션 오류  (2) 2008.02.28
소켓shutdown..DomainName<->IP  (0) 2006.07.18
TCP/IP 추가 and UDP /IP  (0) 2006.07.18
소켓 프로그래밍 part 2~4 TCP/IP  (4) 2006.07.15

Beginning Linux Programming Part6-Curses

여기서 윈도우라는건 콘솔에서 하는겁니당..
터미널 상에서 상자만드는것이죠
GTK,QT,API 이런거 아닙니다..

C대충 아시는 분은 뭐하는지 아실겝니다..
어짜피 다른거라고 해봤자 함수좀 쓰는거니까..
Curses는 도스랑도 꽤나 비슷한가 보군요 구글링 하니까 비슷하더라는..

다음은 요약본

*******윈도우 속성*************

#include<curses.h>

WINDOW initscr(void); //윈도우를 연다
int endwin(void); //윈도우를 닫는다

int move(int x,int y) //커서를 이동한다 x,y 좌표에 따라서,도스의 gotoxy랑 하는짓?은 비슷하다
printw(char *format...)//걍 문자열 출력 일반적 윈도우에서 쓰는 printf 라고 생각하자

int refresh(void);화면 다시 쓰기 (화면 새로 고침)

attron(chtype attribute);//해당 문자 속성을 켠다(A_BOLD,A_UNDERLINE,A_REVERSE.....)
attroff(chtype attribute);//해당 문자 속성을 끈다(옵션은 같이 붙여주면 됨)

ex>
     7     initscr();//윈도우 시작
     8
     9     move(10,10);//Move..
    10     printw("MAC vs Windows");//글자
    11     refresh();//화면 reflash 해야 글자가 보임
    12     sleep(1);
    48
    49     endwin();//윈도우 종료

*아래에 해당되는 함수는 윈도우의 시작과 끝 사이에 위치해야한다
(initscr();~endwin() 사이에)

int echo(void)//echo 켜기(print)
int noecho(void)//echo 끄기
int cbreak(void)//글자를 누르자 마자 직접 반응
int nocbreak(void)//cbreak 끄기
int raw(void) //특수문자 처리가 꺼짐(방향키등)
int noraw(void)//특수문자 처리가 가능

int getch(void) //설명이 필요 없다
int getstr(char *string) //문자열을 입력받는다
int getnstr(char *string,int stringsize)//n개의 문자를 입력받는다(Bufferoverflow 방지)
(strncmp memnset 같은 n 종류)

******Window 건드리기********

기본적인 순서는
1윈도우를 정의한다
2윈도우에 출력할 내용을 정한다
3표준화면에 윈도우를 적용한다

ex>

    10     WINDOW *win1,*win2;//윈도우 구조체 선언(직접 건들진 못한다)
    ....
    24     win1=newwin(10,20,15,12); //새창의 윈도우
    25     mvwprintw(win1,2,2,"%s","Hello World! ");//들어갈 내용
    26
    27     win2=newwin(30,30,30,30);
    28     mvwprintw(win2,2,3,"%s","ABCDEF~");
    29
    30     wrefresh(win2);
    31     wrefresh(win1);//화면에 적용

아까 printw를 예로들자면
wprintw(WINDOW *winpointer,char *format,...);
mvprintw(int x,int y,char *format,...);
mvwprintw(WINDOW *winpointer,int y,int x,char *format,...);

w->WINDOW 포인터
mv->window mv(이동)
mvw->위에꺼 두개 합친것

box(WINDOW *winpointer,char x,char y) ?
상자를 만든다 x,y에다가는 각 테두리를 장식할 문자를 정해주면 된다

*******키패드**********

보통 initscr 했을때 키패드는 이스케이프 문자를 잠근다고 한다
이것을 풀기위해선
keypad()함수를 사용하면 된다

int keypad(WINDOW *winpoiter,TRUE/FALSE);
TRUE,FALSE 중 하나를 택하여 키패드 모드을 on/off한다
뭐 특별히 정해줄거 없으면 stdscr으로 해도 된다

보통 getch();로 받아서 이것을 swich문으로 Check하는데
거기서 키패드가 뭐가 눌렸는지 알수 있는 매크로는 다음과 같다

LOCAL_ESCAPE_KEY
KEY_UP,KEY_DOWN,KEY_RIGHT,KEY_LEFT
KEY_END,KEY_BEG
척 보면 다 아니깐 설명은 생략

ex> 설명은 귀찮아서 안해
    14     do
    15     {
    16         mvprintw(10,15,"UP DOWN RIGHT LEFT Press Key....:");
    17         refresh();
    18
    19         ch=getch();
    20
    21         clear();
    22         move(10,50);
    23
    24         if(ch>='a' && ch <='z')
    25             printw("%c",(char)ch);
    26         else if(ch>='A' && ch <='Z')
    27             printw("%c",(char)ch);
    28         else if(ch>='0' && ch <='9')
    29             printw("%c",(char)ch);
    30
    31         else
    32         switch(ch){
    33             case(KEY_RIGHT):
    34                 printw("RIGHT");
    35                 break;
    36             case(KEY_LEFT):
    37                 printw("LEFT");
    38                 break;
    39             case(KEY_UP):
    40                 printw("UP");
    41                 break;
    42             case(KEY_DOWN):
    43                 printw("DOWN");
    44                 break;
    45             default:
    46                 printw("KEY VALUE:%d",ch);
    47         }
    48
    49     }while(ch != 'q');

*************색깔(color)****************

소스를 보면서 설명

    18     has_colors(); //터미널이 색깔을 쓸수 있는지 확인
    19     start_color(); //색깔쓰기 시작 안되면 에러메세지

    20     init_pair(1,COLOR_RED,COLOR_BLACK); //여기서 부터 번호대로 색깔을 정의한다
    21     init_pair(2,COLOR_BLUE,COLOR_WHITE);
    22     init_pair(3,COLOR_CYAN,COLOR_YELLOW);
    23     init_pair(4,COLOR_GREEN,COLOR_RED);
    24     init_pair(5,COLOR_WHITE,COLOR_MAGENTA);
    25     init_pair(6,COLOR_BLACK,COLOR_WHITE);
    26     init_pair(7,COLOR_RED,COLOR_GREEN);
    27     init_pair(8,COLOR_MAGENTA,COLOR_CYAN);
//RED,BLACK..이런 건 아마 curses.h에 메크로로 존재하는거 같다~!

    29     for(i=1;i<9;i++){
    30         attrset(COLOR_PAIR(i) | A_BOLD);//
    31         //wattron(stdscr,COLOR_PAIR(i) | A_BOLD );
//일정 WINDOW 포인터에 적을때 사용지금은 그냥 stdscr이므로 위의 함수와 하는일이 같다

    32         mvprintw(13+i,10,"%s%d              %s%d",str1,i,str2,i);
//일정한 위치에 글자를 찍어라 앞에서도 봤던 함수 %d %s %c 같이  printf의 포맷과 비슷하다

    33         refresh(); //전에도 말했지만 변경사항을 적용할려면 refresh함수를 써야한다
    34         sleep(1); //바로 지나가므로 결과를 확인할수 있게 잠시 늦춤
    35     }

********** 패드 (pad) **************

에 그러니까.. 패드라는건.. 나도 뭔가 했는데..
책에서 논리화면 물리화면 어쩼네~ 이러는건.. 이해가 안되서..
내가 내맘대로 이해한게 화면을 쓸수 있는 범위랄까 .. 그런걸 지정한다고
해버림

WINDOW *newpad(int number_of_lines,int number_of_columns);
뭐.. 설명이 필요할까

#include<curses.h> //외워 버렸네..
int prefresh(WINDOW *pad-ptr,int pad_row,int pad_column,
                       int screen_row_min,int screen_col_min,
                       int screen_row_max,int screen_col_min)

아따 길다.. 뭐이리 길어... 이것도 다 적혀있으니깐 해설은 Pass~

ex> //설명이구 뭐구 할께 없다.. 그 자체
사실 나도 별내용 없는거 같아서 책 내용 그대로 쳐봤다..

    28     prefresh(pad,5,7,2,2,9,9);
    29     sleep(1);
    30
    31     prefresh(pad,LINES +5,COLS +7,5,5,21,19);
    32     sleep(1);
    33     delwin(pad); //윈도우를 지운다

뒤에 뭐 CD  응용프로그램 만든다고 하는데..
나는 갈길이 바뻐서.. 뭐 이것도 넘어가기로 한다

아~ 그러니깐 이번 파트 끝이넹.. 이것도 2틀이나 걸렸다..(터미널이랑 같다?)
정말 의외로 시간이 정말 오래 걸리는군... 하아.. 뭐.. 이정도 속도로가면 한 3주내에
빠르면 2주만에 끝낼수도 잇을텐데.. (뭐.. 빼먹을 부분이 좀 있는지라)

다음은 11장 프로세스~

'Programming > System' 카테고리의 다른 글

MBR(?) 출력 하기  (2) 2007.06.17
screen attach dettach 구별법  (2) 2007.02.12
ls -al  (0) 2006.06.21
Beginning linux programming  (6) 2006.03.01
VIRUS 제작~  (6) 2006.01.03
prev 1 ··· 14 15 16 17 18 19 next