2016-06-01 1 views
0

사용자가 버튼을 누를 때 네트워크에 연결할 GUI를 만들려고합니다. gui_ex.cpp 파일을 컴파일 할 때 컴파일 오류가 발생합니다.gtkmm3을 사용하는 소켓 서버

gui_ex.cpp: In member function ‘void Gui_Ex::on_connect()’: 
gui_ex.cpp:110:19: error: no matching function for call to ‘Gui_Ex::close(int&)’ 
     close(sock); 
       ^
gui_ex.cpp:110:19: note: candidate is: 
In file included from /usr/include/gtkmm-3.0/gtkmm/dialog.h:30:0, 
       from /usr/include/gtkmm-3.0/gtkmm/aboutdialog.h:33, 
       from /usr/include/gtkmm-3.0/gtkmm.h:99, 
       from gui_ex.h:4, 
       from gui_ex.cpp:1: 
/usr/include/gtkmm-3.0/gtkmm/window.h:2026:8: note: void Gtk::Window::close() 
    void close(); 
     ^
/usr/include/gtkmm-3.0/gtkmm/window.h:2026:8: note: candidate expects 0 arguments, 1 provided 
gui_ex.cpp:117:19: error: no matching function for call to ‘Gui_Ex::close(int&)’ 
     close(sock); 
       ^
gui_ex.cpp:117:19: note: candidate is: 
In file included from /usr/include/gtkmm-3.0/gtkmm/dialog.h:30:0, 
       from /usr/include/gtkmm-3.0/gtkmm/aboutdialog.h:33, 
       from /usr/include/gtkmm-3.0/gtkmm.h:99, 
       from gui_ex.h:4, 
       from gui_ex.cpp:1: 
/usr/include/gtkmm-3.0/gtkmm/window.h:2026:8: note: void Gtk::Window::close() 
    void close(); 
     ^
/usr/include/gtkmm-3.0/gtkmm/window.h:2026:8: note: candidate expects 0 arguments, 1 provided 

소켓의 닫기 명령과 Gtk :: Window의 닫기 명령 사이에서 프로그램이 혼동하는 것 같습니다. 컴파일러가 두 코드를 구별 할 수 있도록 코드를 조정할 수 있습니까? gui_ex.h 파일

#ifndef GTKMM_EX_GUI_H 
#define GTKMM_EX_GUI_H 

#include <gtkmm.h> 

class Gui_Ex : public Gtk::Window 
{ 
public: 
    Gui_Ex(); 
    virtual ~Gui_Ex(); 

protected: 
    // Signal handlers: 
    // new button 
    void on_connect(); 
    void on_spin(); 

    //void on_spinbutton_digits_changed(); 

    //child widgets 
    //Gtk::Frame m_Frame_Init, m_Frame_Control; 
    Glib::RefPtr<Gtk::Adjustment> m_adjustment; 
    Gtk::Label m_label; 
    Gtk::Grid m_grid; 

    Gtk::SpinButton m_spin; 
    Gtk::Button m_button2, m_button3; //m_connect; 



}; 

#endif // GTKMM_EX_GUI_H 

gui_ex.cpp 당신은 바로 여기에 명시 적으로 글로벌 네임 스페이스를 호출 할 필요가

#include "gui_ex.h" 
#include <iostream> 
#include <stdio.h> 
#include <stdlib.h> 
#include <iostream> 
#include <cstring> 
#include <string.h> // memset 
#include <pthread.h> 
#include <sys/socket.h> 
#include <arpa/inet.h> 
#include <netinet/in.h> 
#include <unistd.h> 
#include <netdb.h> 
#include <vector> 
#include <string> 
using namespace std; 

#define PORT "8888" 
//#define BACKLOG 2 
#define IP_ADDR "192.168.137.99" 
#define MAXLEN 1024 

int BACKLOG =0; 
static unsigned int cli_count = 0; 
static int uid = 20; 
vector<int> cliarray; 

Gui_Ex::Gui_Ex() 
: 
    // m_button1("Button 1"), 
    m_adjustment(Gtk::Adjustment::create(1.0, 1.0, 5.0, 1.0, 5.0, 0.0)), 
    m_button2("Enter"), 
    m_button3("Connect"), 
    m_spin(m_adjustment), 
    m_label("Choose # clients") 


{ 
    set_title("Grid"); 
    set_border_width(12); 


    m_grid.attach(m_label, 0,0,1,1); //column, row, width (# col span), height (# row span) 
    m_grid.attach(m_spin, 1,0,1,1); 
    m_spin.set_wrap(); 
    m_spin.set_numeric(true); 

    m_grid.attach(m_button2, 2,0,1,1); 

    m_grid.attach(m_button3, 0,1,3,1); 
    m_button3.set_sensitive(false); 

    m_button2.signal_clicked().connect(sigc::mem_fun(*this, &Gui_Ex::on_spin)); 
    m_button3.signal_clicked().connect(sigc::mem_fun(*this, &Gui_Ex::on_connect)); 
    //m_button3.signal_clicked().connect(sigc::bind<int>(sigc::mem_fun(*this, &Gui_Ex::on_connect), m_spin.get_value_as_int())); 

    add(m_grid); 
    m_grid.show_all(); 
    //show_all_children(); 

} 

Gui_Ex::~Gui_Ex() 
{ 
} 


void Gui_Ex::on_spin() 
{ 
    cout<<"Spin value =: " << m_spin.get_value_as_int() << endl; 
    BACKLOG = m_spin.get_value_as_int(); 
    m_spin.set_sensitive(false); 
    m_button2.set_sensitive(false); 
    m_button3.set_sensitive(true); 

} 

void Gui_Ex::on_connect() 
{ 
    int connfd =0, n = 0; 
    int *new_sock, sock; 

    cout << BACKLOG << endl; 
    pthread_t thread; 
    struct addrinfo hints, *res; 
    int reuseaddr = 1; // True 

    // Get the address info 
    memset(&hints, 0, sizeof hints); 
    hints.ai_family = AF_INET; 
    hints.ai_socktype = SOCK_STREAM; 
    if (getaddrinfo(IP_ADDR, PORT, &hints, &res) != 0) { 
     perror("getaddrinfo"); 
     //return 1; 
    } 

    // Create the socket 
    sock = socket(res->ai_family, res->ai_socktype, res->ai_protocol); 
    if (sock == -1) { 
     perror("socket"); 
     // return 1; 
    } 

    // Enable the socket to reuse the address 
    if (setsockopt(sock, SOL_SOCKET, SO_REUSEADDR, &reuseaddr, sizeof(int)) == -1) { 
     perror("setsockopt"); 
     close(sock); 
     // return 1; 
    } 

    // Bind to the address 
    if (bind(sock, res->ai_addr, res->ai_addrlen) == -1) { 
     perror("bind"); 
     close(sock); 
     //return 0; 
    } 

    freeaddrinfo(res); 

    // Listen 
    if (listen(sock, BACKLOG) == -1) { 
     perror("listen"); 
     // return 0; 
    } 
    cout << "listening for connections" << endl; 
    // Main loop 
    bool running = true; 
    // Initialize clients 
    while (running) 
    { 
     size_t size = sizeof(struct sockaddr_in); 
     struct sockaddr_in their_addr; 
     int clilen = sizeof(their_addr); 
     int newsock = accept(sock, (struct sockaddr*)&their_addr, &size); 
     if (newsock == -1) 
     { 
     perror("accept"); 
     // return -1; 
     } 
     cli_count++; 
     printf("Got a connection from %s on port %d\n", inet_ntoa(their_addr.sin_addr), htons(their_addr.sin_port)); 
     cliarray.push_back(newsock); 
     if (cli_count == BACKLOG) 
     { 
     cout << "Max clients reached" << endl; 
     running = false; 
     break; 
     } 
    } 
} 

답변

1

:

여기 내 코드입니다. 기본적으로

::close(sock); 

, 대상 네임 스페이스 가죽의 close 방법의 존재 : 즉, 때 대신 기본 클래스의 close 방법의 libc의 close 함수를 호출하려고, 당신은 전역 네임 스페이스 부호를 앞에 추가한다 같은 이름의 글로벌 심볼. 더 자세한 설명을 보려면 첫 번째 답변을 참조하십시오. Global scope vs global namespace

+0

감사합니다. – nt387