Çözüldü Granny updateleme problemi

  • Konuyu açan Konuyu açan Kuqsal
  • Açılış Tarihi Açılış Tarihi
  • Yanıt Yanıt 2
  • Gösterim Gösterim 501
Bu konu çözüme ulaştırılmıştır. Çözüm için konuya yazılan tüm yorumları okumayı unutmayın. Eğer konudaki yorumlar sorununuzu çözmediyse yeni bir konu açabilirsiniz.
Durum
İçerik kilitlendiği için mesaj gönderimine kapatıldı.

Kuqsal

Üye
Üye
Mesaj
107
Çözümler
10
Beğeni
22
Puan
459
Ticaret Puanı
0
Granny updatelemeye calıstığımda böyle problem alıyorum kullandığım files mmotutkunları filesinde

Bence sebebi bu fakat bilemiyorum sanki libi almıyor gibi ama nasıl libi göstereceğim bilmiyorumda
Linkleri görebilmek için giriş yap veya kayıt ol.


Problem bu:
Linkleri görebilmek için giriş yap veya kayıt ol.


C++:
Genişlet Daralt Kopyala
// GrannyConverter.cpp : Defines the entry point for the console application.
//

#include "stdafx.h"
#include <EterBase/Filename.h>
#include <EterBase/CRC32.h>
#include <granny.h>

#pragma warning(push)
#pragma warning(disable:4100)
#pragma warning(disable:4127)
#pragma warning(disable:4189)
#pragma warning(disable:4512)
#pragma warning(disable:4706)
#include <cryptopp-5.6.0/cryptlib.h>
#include <cryptopp-5.6.0/filters.h>
#include <cryptopp-5.6.0/modes.h>
#include <cryptopp-5.6.0/sha.h>
#include <cryptopp-5.6.0/tiger.h>
#include <cryptopp-5.6.0/ripemd.h>
#include <cryptopp-5.6.0/whrlpool.h>
#include <cryptopp-5.6.0/des.h>
#include <cryptopp-5.6.0/aes.h>
#include <cryptopp-5.6.0/tea.h>
#include <cryptopp-5.6.0/osrng.h>
#include <cryptopp-5.6.0/salsa.h>
#include <cryptopp-5.6.0/panama.h>
#include <cryptopp-5.6.0/sosemanuk.h>
#include <cryptopp-5.6.0/cryptoppLibLink.h>
#pragma warning(pop)
#include <boost/timer.hpp>

#pragma comment(lib, "granny2.lib")

struct CryptoTester
{
    CryptoTester() : Encryptor(NULL), Decryptor(NULL), elapsedTime(0.0) {}
    CryptoPP::StreamTransformation* Encryptor;
    CryptoPP::StreamTransformation* Decryptor;
    double elapsedTime;
};

template <class N> void SetupCrypto(std::vector<CryptoTester>& vector, const byte* key, const byte* iv)
{
    CryptoTester res;

    res.Encryptor = new N::Encryption;
    res.Decryptor = new N::Decryption;

    CryptoPP::SimpleKeyingInterface* keyInterface = dynamic_cast<CryptoPP::SimpleKeyingInterface*>(res.Encryptor);
    CryptoPP::SimpleKeyingInterface* keyInterface2 = dynamic_cast<CryptoPP::SimpleKeyingInterface*>(res.Decryptor);

    if (keyInterface->IVRequirement() != CryptoPP::SimpleKeyingInterface::NOT_RESYNCHRONIZABLE)
    {
        keyInterface->SetKeyWithIV(key, keyInterface->MaxKeyLength(), iv, keyInterface->MaxIVLength());
        keyInterface2->SetKeyWithIV(key, keyInterface->MaxKeyLength(), iv, keyInterface->MaxIVLength());
    }
    else
    {
        keyInterface->SetKey(key, keyInterface->MaxKeyLength());
        keyInterface2->SetKey(key, keyInterface->MaxKeyLength());
    }

    vector.push_back(res);
}

int _tmain(int argc, char* argv[])
{
    if (argc != 2)
        return 1;

    char arg1[1024 + 1];
    strcpy_s(arg1, sizeof(arg1), argv[1]);

    CFilename Gr2FileName(arg1);
    
    CFilename RawFileName(Gr2FileName.NoExtension());
    RawFileName += ".ygr";

    CFilename NewGr2FileName(Gr2FileName.NoExtension());
    NewGr2FileName += "_new.gr2";

    granny_file* gr2File = GrannyReadEntireFile(Gr2FileName.c_str());
    granny_int32x FileSectionCount;
    granny_file_info * FileInfo;

    if (gr2File)
    {
        FileSectionCount = gr2File->SectionCount;
        FileInfo = GrannyGetFileInfo(gr2File);

        GrannyConvertFileInfoToRaw(FileInfo, RawFileName.c_str());
    }

    FILE * fp;
    
    if (0 == fopen_s(&fp, RawFileName.c_str(), "rb") && fp)
    {
        fseek(fp, 0L, SEEK_END);
        long FileSize = ftell(fp);
        fseek(fp, 0L, SEEK_SET);
        char * Buffer = (char *) malloc(FileSize);
        printf("FileSize: %u\n", fread(Buffer, sizeof(char), FileSize, fp));
        fclose(fp);

        // 파일 이름으로 부터 암호화 키를 생성함 (다른 파일로 이름 바꿔서 사용하기 힘들어짐)
        std::string SrcStringForKey(RawFileName);
        CryptoPP::HashTransformation* hm = NULL;
        unsigned int idx = GetCRC32(SrcStringForKey.c_str(), SrcStringForKey.length()) & 3;

        // 키 암호화
        byte key[32];

        CryptoPP::HashTransformation* hm1 = NULL;
        CryptoPP::HashTransformation* hm2 = NULL;

        static CryptoPP::Tiger tiger;
        static CryptoPP::SHA1 sha1;
        static CryptoPP::RIPEMD128 ripemd128;
        static CryptoPP::Whirlpool whirlpool;

        switch (idx & 3)
        {
            case 0:
                hm1 = &whirlpool;
                break;

            case 1:
                hm1 = &tiger;
                break;

            case 2:
                hm1 = &sha1;
                break;

            case 3:
                hm1 = &ripemd128;
                break;
        }

        CryptoPP::StringSource(SrcStringForKey, true,
                         new CryptoPP::HashFilter(*hm1,
                            //new CryptoPP::HexEncoder(
                                new CryptoPP::ArraySink(key, sizeof(key) - 16)
                            //) // HexEncoder
                         ) // HashFilter
                     ); // StringSource

        // 만들어진 키의 첫번째 4바이트로 다음 16바이트 키 생성 알고리즘 선택
        unsigned int idx2 = *(unsigned int*) key;

        switch (idx2 & 3)
        {
            case 0:
                hm2 = &sha1;
                break;

            case 1:
                hm2 = &ripemd128;
                break;

            case 2:
                hm2 = &whirlpool;
                break;

            case 3:
                hm2 = &tiger;
                break;
        }

        CryptoPP::StringSource(SrcStringForKey, true,
                         new CryptoPP::HashFilter(*hm2,
                            //new CryptoPP::HexEncoder(
                                new CryptoPP::ArraySink(key + 16, sizeof(key) - 16)
                            //) // HexEncoder
                         ) // HashFilter
                     ); // StringSource
        // 키 생성 완료

        // IV 생성
        CryptoPP::AutoSeededRandomPool prng;
        byte iv[32];
        prng.GenerateBlock(iv, sizeof(iv));

        // Crypto들 셋업
        std::vector<CryptoTester> tester;

        SetupCrypto<CryptoPP::ECB_Mode<CryptoPP::AES> >(tester, key, iv);
        SetupCrypto<CryptoPP::CBC_Mode<CryptoPP::AES> >(tester, key, iv);
        SetupCrypto<CryptoPP::PanamaCipher<CryptoPP::LittleEndian> >(tester, key, iv);
        SetupCrypto<CryptoPP::Salsa20>(tester, key, iv);
        SetupCrypto<CryptoPP::XSalsa20>(tester, key, iv);
        SetupCrypto<CryptoPP::Sosemanuk>(tester, key, iv);
        SetupCrypto<CryptoPP::CBC_Mode<CryptoPP::XTEA> >(tester, key, iv);
        SetupCrypto<CryptoPP::ECB_Mode<CryptoPP::XTEA> >(tester, key, iv);

        std::string CipherText;  // 암호화에 사용될 임시 버퍼
        std::string DecryptText;  // 복호화에 사용될 임시 버퍼

        double nonono = 0.0;

        for (int i = 0; i < 1024; ++i)
        {
            CipherText.clear();
            DecryptText.clear();

            std::vector<CryptoTester>::iterator it = tester.begin();

            while (it != tester.end())
            {
                CryptoTester& tester = *(it++);

                boost::timer t;

                CryptoPP::ArraySource((const byte*) Buffer, FileSize, true,
                    new CryptoPP::StreamTransformationFilter(*tester.Encryptor,
                        new CryptoPP::StringSink(CipherText)
                    )
                );

                CryptoPP::ArraySource(CipherText, true,
                    new CryptoPP::StreamTransformationFilter(*tester.Decryptor,
                        new CryptoPP::StringSink(DecryptText)
                    )
                );

                tester.elapsedTime += t.elapsed();
            }

            boost::timer t;

            for (int k = 0; k < FileSize >> 5; k += 32)
                CipherText.replace(k, 32, Buffer + k, 32);

            const char * text = CipherText.c_str();

            for (int k = 0; k < FileSize >> 5; k += 32)
                DecryptText.replace(k, 32, text + k, 32);

            nonono += t.elapsed();
        }

        std::vector<CryptoTester>::iterator it = tester.begin();

        while (it != tester.end())
        {
            CryptoTester& tester = *(it++);
            printf("%s %g\n", tester.Encryptor->AlgorithmName().c_str(), tester.elapsedTime);
        }

        printf("No Crypto: %g\n", nonono);

        // 다시 그래니 파일로 저장
        FileInfo = (granny_file_info *)DecryptText.c_str();

        GrannyRebasePointers(GrannyFileInfoType, (void*) FileInfo, (int) FileInfo, true);

        granny_int32x DefaultSectionIndex = 0;

        int artToolSize = GrannyGetTotalObjectSize(GrannyArtToolInfoType);

        granny_file_data_tree_writer *DataTreeWriter =
           GrannyBeginFileDataTreeWriting(GrannyFileInfoType, FileInfo,
                                     DefaultSectionIndex,
                                     DefaultSectionIndex);

        GrannyWriteDataTreeToFile(DataTreeWriter, GrannyCurrentGRNStandardTag,
                             NewGr2FileName.c_str(),
                             FileSectionCount);

        GrannyEndFileDataTreeWriting(DataTreeWriter);

        free(Buffer);
    }

    return 0;
}
 
Son düzenleme:
Çözüm
Lib hatası değil, EterGrnLib hatadan dolayı derlenemediği için .lib dosyası oluşmuyor. Lib dosyası oluşmayınca da UserInterface bu lib'i bulamadığı için hata veriyor. Yani onu es geç.

GrannyNewMeshDeformer adlı fonksiyonu her yerde kontrol et, tanımlanan ve kullanılan argüman sayıları uyuşmadığı için o hatayı veriyor.(ya da tam tersi)
hangi konudan yapmaya çalıştığınız gönderir misiniz inceleyip hatayı bulalım
 
Lib hatası değil, EterGrnLib hatadan dolayı derlenemediği için .lib dosyası oluşmuyor. Lib dosyası oluşmayınca da UserInterface bu lib'i bulamadığı için hata veriyor. Yani onu es geç.

GrannyNewMeshDeformer adlı fonksiyonu her yerde kontrol et, tanımlanan ve kullanılan argüman sayıları uyuşmadığı için o hatayı veriyor.(ya da tam tersi)
 
Çözüm
Durum
İçerik kilitlendiği için mesaj gönderimine kapatıldı.
Geri
Üst