lib/javacompat: Make this a header library
Cygwin build issues were caused by lib/nbt impleicitly linking against thisbroken
parent
e0994e5db8
commit
5ff8a871ad
|
@ -59,7 +59,7 @@ echo ">>> Building tools..."
|
||||||
create_directory bin/tools
|
create_directory bin/tools
|
||||||
# add compile commands to this array
|
# add compile commands to this array
|
||||||
COMPILE_COMMANDS=(
|
COMPILE_COMMANDS=(
|
||||||
"$CXX_WITH_FLAGS src/tools/dumpnbt.cpp -I./include -Lbin/lib -l:nbt.so -l:javacompat.so -l:cli.so -o bin/tools/dumpnbt"
|
"$CXX_WITH_FLAGS src/tools/dumpnbt.cpp -I./include -Lbin/lib -l:nbt.so -l:cli.so -o bin/tools/dumpnbt"
|
||||||
"$CXX_WITH_FLAGS src/tools/arraydump.cpp -I./include -Lbin/lib -l:file.so -l:cli.so -o bin/tools/arraydump"
|
"$CXX_WITH_FLAGS src/tools/arraydump.cpp -I./include -Lbin/lib -l:file.so -l:cli.so -o bin/tools/arraydump"
|
||||||
"$CXX_WITH_FLAGS src/tools/baseconvert.cpp -I./include -Lbin/lib -l:cli.so -o bin/tools/baseconvert"
|
"$CXX_WITH_FLAGS src/tools/baseconvert.cpp -I./include -Lbin/lib -l:cli.so -o bin/tools/baseconvert"
|
||||||
"$CXX_WITH_FLAGS -pthread src/tools/hexnet.cpp -I./include -Lbin/lib -l:cli.so -l:libsockpp.so -o bin/tools/hexnet"
|
"$CXX_WITH_FLAGS -pthread src/tools/hexnet.cpp -I./include -Lbin/lib -l:cli.so -l:libsockpp.so -o bin/tools/hexnet"
|
||||||
|
|
|
@ -33,11 +33,11 @@ echo ">>> Building tests..."
|
||||||
|
|
||||||
# add compile commands to this array
|
# add compile commands to this array
|
||||||
COMPILE_COMMANDS=(
|
COMPILE_COMMANDS=(
|
||||||
"$CXX_WITH_FLAGS src/test/nbt_read_write_helpers.cpp -I./include -Lbin/lib -l:nbt.so -l:javacompat.so -o bin/test/nbt_read_write_helpers"
|
"$CXX_WITH_FLAGS src/test/nbt_read_write_helpers.cpp -I./include -Lbin/lib -l:nbt.so -o bin/test/nbt_read_write_helpers"
|
||||||
"$CXX_WITH_FLAGS src/test/cli_argument_parser.cpp -Lbin/lib -l:cli.so -o bin/test/cli_argument_parser"
|
"$CXX_WITH_FLAGS src/test/cli_argument_parser.cpp -Lbin/lib -l:cli.so -o bin/test/cli_argument_parser"
|
||||||
"$CXX_WITH_FLAGS src/test/javacompat.cpp -I./include -Lbin/lib -l:javacompat.so -o bin/test/javacompat"
|
"$CXX_WITH_FLAGS src/test/javacompat.cpp -I./include -Lbin/lib -o bin/test/javacompat"
|
||||||
"$CXX_WITH_FLAGS src/test/nbt_tags.cpp -I./include -Lbin/lib -l:nbt.so -l:javacompat.so -o bin/test/nbt_tags"
|
"$CXX_WITH_FLAGS src/test/nbt_tags.cpp -I./include -Lbin/lib -l:nbt.so -o bin/test/nbt_tags"
|
||||||
"$CXX_WITH_FLAGS src/test/nbt_size_helpers.cpp -I./include -Lbin/lib -l:nbt.so -l:javacompat.so -o bin/test/nbt_size_helpers"
|
"$CXX_WITH_FLAGS src/test/nbt_size_helpers.cpp -I./include -Lbin/lib -l:nbt.so -o bin/test/nbt_size_helpers"
|
||||||
"$CXX_WITH_FLAGS src/test/file.cpp -I./include -Lbin/lib -l:file.so -o bin/test/file"
|
"$CXX_WITH_FLAGS src/test/file.cpp -I./include -Lbin/lib -l:file.so -o bin/test/file"
|
||||||
)
|
)
|
||||||
for command in ${!COMPILE_COMMANDS[@]}; do
|
for command in ${!COMPILE_COMMANDS[@]}; do
|
||||||
|
|
|
@ -1,94 +0,0 @@
|
||||||
//Copyright 2022, FOSS-VG Developers and Contributers
|
|
||||||
//
|
|
||||||
//This program is free software: you can redistribute it and/or modify it
|
|
||||||
//under the terms of the GNU Affero General Public License as published
|
|
||||||
//by the Free Software Foundation, version 3.
|
|
||||||
//
|
|
||||||
//This program is distributed in the hope that it will be useful,
|
|
||||||
//but WITHOUT ANY WARRANTY; without even the implied
|
|
||||||
//warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
|
|
||||||
//See the GNU Affero General Public License for more details.
|
|
||||||
//
|
|
||||||
//You should have received a copy of the GNU Affero General Public License
|
|
||||||
//version 3 along with this program.
|
|
||||||
//If not, see https://www.gnu.org/licenses/agpl-3.0.en.html
|
|
||||||
|
|
||||||
#include <tinyutf8/tinyutf8.h>
|
|
||||||
#include <string>
|
|
||||||
#include "error.hpp"
|
|
||||||
#include "javacompat.hpp"
|
|
||||||
#include "../../.endianness"
|
|
||||||
|
|
||||||
#ifdef FOSSVG_ENDIAN_BIG_WORD
|
|
||||||
#error "Honeywell-316-style endianness is not supported. If you feel like it should, feel free to participate in the project to maintain it."
|
|
||||||
#endif
|
|
||||||
#ifdef FOSSVG_ENDIAN_LITTLE_WORD
|
|
||||||
#error "PDP-11-style endianness is not supported. If you feel like it should, feel free to participate in the project to maintain it."
|
|
||||||
#endif
|
|
||||||
#ifdef FOSSVG_ENDIAN_UNKNOWN
|
|
||||||
#error "The endianness of your system could not be determined. Please set it manually. FOSS-VG is currently implemented using some endian-specific functions."
|
|
||||||
#endif
|
|
||||||
|
|
||||||
namespace JavaCompat {
|
|
||||||
ErrorOr<tiny_utf8::string> importJavaString(uint8_t data[], uint16_t size) {
|
|
||||||
std::string stdString;
|
|
||||||
uint16_t encodedSize = static_cast<uint16_t>(data[0])<<8 | static_cast<uint16_t>(data[1]);
|
|
||||||
|
|
||||||
if(encodedSize != size){
|
|
||||||
return ErrorOr<tiny_utf8::string>(true, ErrorCodes::MISMATCHEDSIZE);
|
|
||||||
}
|
|
||||||
|
|
||||||
for(uint16_t i=2; i<size+2; i++){
|
|
||||||
if(i != 0){
|
|
||||||
if(data[i] == 0x80 && data[i-1] == 0xc0){
|
|
||||||
stdString[stdString.length() - 1] = '\0';
|
|
||||||
continue;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
stdString.push_back((char) data[i]);
|
|
||||||
}
|
|
||||||
return ErrorOr<tiny_utf8::string>(tiny_utf8::string(stdString));
|
|
||||||
}
|
|
||||||
|
|
||||||
ErrorOr<std::vector<uint8_t>> exportJavaString(tiny_utf8::string data) {
|
|
||||||
uint16_t* size = new uint16_t;
|
|
||||||
uint8_t* sizeBytes = reinterpret_cast<uint8_t*>(size);
|
|
||||||
std::vector<uint8_t> output = std::vector<uint8_t>();
|
|
||||||
std::string stdString = data.cpp_str();
|
|
||||||
|
|
||||||
if(stdString.size() > 0xFFFF){
|
|
||||||
return ErrorOr<std::vector<uint8_t>>(true, ErrorCodes::OVERRUN);
|
|
||||||
}
|
|
||||||
|
|
||||||
*size = (uint16_t) stdString.size();
|
|
||||||
|
|
||||||
//placeholder size bytes
|
|
||||||
output.push_back(0x00);
|
|
||||||
output.push_back(0x00);
|
|
||||||
for(uint16_t i=0; i<stdString.size(); i++){
|
|
||||||
if((uint8_t) stdString[i] == 0x00){
|
|
||||||
*size += 1;
|
|
||||||
output.push_back(0xc0);
|
|
||||||
output.push_back(0x80);
|
|
||||||
continue;
|
|
||||||
}
|
|
||||||
output.push_back(stdString[i]);
|
|
||||||
}
|
|
||||||
|
|
||||||
//FIXME: endian-dependent implementation
|
|
||||||
#ifdef FOSSVG_BIG_ENDIAN
|
|
||||||
output[0] = *sizeBytes;
|
|
||||||
output[1] = *(sizeBytes+1);
|
|
||||||
#else
|
|
||||||
#ifdef FOSSVG_LITTLE_ENDIAN
|
|
||||||
output[0] = *(sizeBytes+1);
|
|
||||||
output[1] = *sizeBytes;
|
|
||||||
#else
|
|
||||||
#error "JavaCompat::exportJavaString: An implementation for your endianness is unavailable."
|
|
||||||
#endif
|
|
||||||
#endif
|
|
||||||
|
|
||||||
return ErrorOr(output);
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
|
|
@ -13,11 +13,81 @@
|
||||||
//version 3 along with this program.
|
//version 3 along with this program.
|
||||||
//If not, see https://www.gnu.org/licenses/agpl-3.0.en.html
|
//If not, see https://www.gnu.org/licenses/agpl-3.0.en.html
|
||||||
|
|
||||||
#include <vector>
|
|
||||||
#include <tinyutf8/tinyutf8.h>
|
#include <tinyutf8/tinyutf8.h>
|
||||||
|
#include <string>
|
||||||
#include "error.hpp"
|
#include "error.hpp"
|
||||||
|
#include "../../.endianness"
|
||||||
|
|
||||||
|
#ifdef FOSSVG_ENDIAN_BIG_WORD
|
||||||
|
#error "Honeywell-316-style endianness is not supported. If you feel like it should, feel free to participate in the project to maintain it."
|
||||||
|
#endif
|
||||||
|
#ifdef FOSSVG_ENDIAN_LITTLE_WORD
|
||||||
|
#error "PDP-11-style endianness is not supported. If you feel like it should, feel free to participate in the project to maintain it."
|
||||||
|
#endif
|
||||||
|
#ifdef FOSSVG_ENDIAN_UNKNOWN
|
||||||
|
#error "The endianness of your system could not be determined. Please set it manually. FOSS-VG is currently implemented using some endian-specific functions."
|
||||||
|
#endif
|
||||||
|
|
||||||
namespace JavaCompat {
|
namespace JavaCompat {
|
||||||
ErrorOr<tiny_utf8::string> importJavaString(uint8_t data[], uint16_t size);
|
ErrorOr<tiny_utf8::string> importJavaString(uint8_t data[], uint16_t size) {
|
||||||
ErrorOr<std::vector<uint8_t>> exportJavaString(tiny_utf8::string data);
|
std::string stdString;
|
||||||
|
uint16_t encodedSize = static_cast<uint16_t>(data[0])<<8 | static_cast<uint16_t>(data[1]);
|
||||||
|
|
||||||
|
if(encodedSize != size){
|
||||||
|
return ErrorOr<tiny_utf8::string>(true, ErrorCodes::MISMATCHEDSIZE);
|
||||||
|
}
|
||||||
|
|
||||||
|
for(uint16_t i=2; i<size+2; i++){
|
||||||
|
if(i != 0){
|
||||||
|
if(data[i] == 0x80 && data[i-1] == 0xc0){
|
||||||
|
stdString[stdString.length() - 1] = '\0';
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
stdString.push_back((char) data[i]);
|
||||||
|
}
|
||||||
|
return ErrorOr<tiny_utf8::string>(tiny_utf8::string(stdString));
|
||||||
|
}
|
||||||
|
|
||||||
|
ErrorOr<std::vector<uint8_t>> exportJavaString(tiny_utf8::string data) {
|
||||||
|
uint16_t* size = new uint16_t;
|
||||||
|
uint8_t* sizeBytes = reinterpret_cast<uint8_t*>(size);
|
||||||
|
std::vector<uint8_t> output = std::vector<uint8_t>();
|
||||||
|
std::string stdString = data.cpp_str();
|
||||||
|
|
||||||
|
if(stdString.size() > 0xFFFF){
|
||||||
|
return ErrorOr<std::vector<uint8_t>>(true, ErrorCodes::OVERRUN);
|
||||||
|
}
|
||||||
|
|
||||||
|
*size = (uint16_t) stdString.size();
|
||||||
|
|
||||||
|
//placeholder size bytes
|
||||||
|
output.push_back(0x00);
|
||||||
|
output.push_back(0x00);
|
||||||
|
for(uint16_t i=0; i<stdString.size(); i++){
|
||||||
|
if((uint8_t) stdString[i] == 0x00){
|
||||||
|
*size += 1;
|
||||||
|
output.push_back(0xc0);
|
||||||
|
output.push_back(0x80);
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
output.push_back(stdString[i]);
|
||||||
|
}
|
||||||
|
|
||||||
|
//FIXME: endian-dependent implementation
|
||||||
|
#ifdef FOSSVG_BIG_ENDIAN
|
||||||
|
output[0] = *sizeBytes;
|
||||||
|
output[1] = *(sizeBytes+1);
|
||||||
|
#else
|
||||||
|
#ifdef FOSSVG_LITTLE_ENDIAN
|
||||||
|
output[0] = *(sizeBytes+1);
|
||||||
|
output[1] = *sizeBytes;
|
||||||
|
#else
|
||||||
|
#error "JavaCompat::exportJavaString: An implementation for your endianness is unavailable."
|
||||||
|
#endif
|
||||||
|
#endif
|
||||||
|
|
||||||
|
return ErrorOr(output);
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue