2016-09-15 49 views
0

使用Visual Studio 2013,我遇到了什麼似乎非常奇怪的行爲與調試器,試圖通過調用一些代碼調用libpng。下面是一些代碼:奇怪的VS2013調試器行爲與libpng 1.6.25

#include <iostream> 
#include <sstream> 
#include <conio.h> 
#include <list> 
#include "png.h" 

int keypause(const char * message = 0) { 
    if(message) 
     std::cout << message << std::endl; 
    return _getch(); 
} 

struct chunk_t { 
    png_bytep chunk_ptr; 
    png_size_t length; 
}; 
std::list<chunk_t> chunks; 
std::stringstream flush_target; 

void my_png_error_fn(png_structp png_ptr, png_const_charp message) { 
    std::cout << "Well crap. " << message << std::endl; 
} 

void my_png_write_fn(png_structrp png_ptr, png_bytep data, png_size_t length) { 
    png_bytep chunk = new png_byte[length]; 
    memcpy(chunk, data, length); 
    chunks.push_back({ chunk, length }); 
} 

void my_png_read_fn(png_structrp png_ptr, png_bytep data, png_size_t length) { 
} 

void my_png_flush_fn(png_structp png_ptr) { 
    for(auto chunk : chunks) { 
     flush_target.write((const char *)chunk.chunk_ptr, chunk.length); 
     delete[] chunk.chunk_ptr; 
    } 
    chunks.clear(); 
} 

// ... 

int main(void) { 
    // ... 

    png_structp png_ws_ptr = png_create_write_struct(PNG_LIBPNG_VER_STRING, NULL, my_png_error_fn, my_png_error_fn); 
    if(png_ws_ptr == nullptr) { 
     keypause("png_ws_ptr is null"); 
     return 0; 
    } 

    png_infop info_ptr = png_create_info_struct(png_ws_ptr); 
    if(info_ptr == 0) { 
     keypause("info_ptr is null"); 
     png_destroy_write_struct(&png_ws_ptr, (png_infopp)NULL); 
     return 0; 
    } 
    if(setjmp(png_jmpbuf(png_ws_ptr))) { 
     keypause("setjmp failed"); 
     png_destroy_write_struct(&png_ws_ptr, &info_ptr); 
     return 0; 
    } 
    // ... 
    png_set_write_fn(png_ws_ptr, NULL, my_png_write_fn, my_png_flush_fn); 
    // ... 
    png_write_png(png_ws_ptr, info_ptr, PNG_TRANSFORM_IDENTITY, NULL); 

    keypause("All done!"); 
    return 0; 
} 

的問題顯示出來,當我嘗試設置一個斷點之外的地方調用png_create_write_struct。 IDE聲稱該斷點與目標中的任何編譯代碼不對應。如果我在調用png_create_write_struct之前設置了一個斷點,我可以進入該函數(我正在鏈接一個libpng的調試版本),一路通過它,然後退出,然後調試器就會丟失。它認爲它在if(png_ws_ptr == nullptr) {區塊內,如果我繼續單擊「Step Over」,當前執行線循環在該區塊內部和周圍。

實際情況是程序運行到main的末尾,我看到最後一次調用keypause時的消息,等待按鍵,然後退出,但實際上沒有寫入任何PNG數據。我在所有回調中設置了斷點,並且沒有一個被觸發。

有沒有其他人遇到過這樣奇怪的事情?有關如何讓調試器行爲的任何建議?

謝謝!

+1

您是以發佈版本還是調試版本的形式調試項目?我的斷點在發佈版本上有怪異的行爲 –

+0

@FirstStep - 絕對是一個Debug版本。我已經做了相同的事情足夠的時間來檢查。 ;-) –

+0

酷然後:)只是檢查你知道 –

回答

2

哇。發現源文件已損壞,並有不匹配的行結束標記(CRLF)。在我關閉並重新打開解決方案之前,我沒有發現這一點,並且我被提示統一線路結束。重建嘗試然後暴露了一些語法錯誤(它告訴我編譯器沒有編譯我認爲是的),修復後得到可正確調試的可執行文件。

這是真正可以得到你的小東西!