** Обновить
я было пытаясь понять, как / почему XCode добавляет странный символ в мой источник C ++, хотя фактически он его удалял. Я создаю простой класс и использую среду тестирования CATCH2, работая над курсом C ++. У меня есть класс numwords, который преобразует числа в слова.
using namespace std;
//int main( int argc, char ** argv )
TEST_CASE("Numwords example", "[numwords]")
{
bw::numword nw;
uint64_t n;
n = 3; REQUIRE( string(nw.words(n)) == "three");
n = 47; REQUIRE( string(nw.words(n)) == "forty-seven");
SUCCEED();
}
Это терпело неудачу с:
/Users/c.craig/Training/CPP/Working/Working/numword-test.cpp:21: FAILED:
REQUIRE( string(nw.words(n)) == "forty-seven" )
with expansion:
"forty-seven" == "forty-seven"
Затем я обнаружил, аккуратно скопировав / вставив ожидаемое значение обратно в мой тест, что действительно было невидимое различие. Вот когда это волшебным образом начало проходить. Я посмотрел на мой git diff и увидел это:
diff --git a/Working/numword-test.cpp b/Working/numword-test.cpp
index c8f58db..3643c03 100755
--- a/Working/numword-test.cpp
+++ b/Working/numword-test.cpp
@@ -18,5 +18,5 @@ TEST_CASE("Numwords example", "[numwords]")
uint64_t n;
n = 3; REQUIRE( string(nw.words(n)) == "three");
- n = 47; REQUIRE( string(nw.words(n)) == "forty-seven^P");
+ n = 47; REQUIRE( string(nw.words(n)) == "forty-seven");
}
Этот странный управляющий символ отображается только в diff и только после того, как я попытался скопировать / вставить текст из diff или из консоли после сбоя. Добавление специального символа вызывает прохождение теста. Если я вручную наберу на клавиатуре значение «сорок семь», специальный символ исчезнет, и он FAILS. Что в мире происходит? Что это за скрытый персонаж ^ P?
Источник для numword.cpp ниже:
#include "numword.hpp"
using namespace bw;
using namespace std;
numword::numword(uint64_t num) : number(num) {
}
static const char * unk = "?";
static const char * ones[] = {"zero", "one", "two", "three", "four", "five", "six", "seven", "eight", "nine", "ten", "eleven", "twelve", "thirteen", "fourteen", "fifteen", "sixteen", "seventeen", "eighteen", "nineteen"};
static const char * tens[] = {"twenty", "thirty", "forty", "fifty", "sixty", "seventy", "eighty", "ninety"};
const char * numword::words(uint64_t num) const {
std::string asString;
if(num < 20)
asString = string(ones[num]);
else if(num < 100){
int index = ((int)num/10)-2;
int x = ((int)num%10);
asString += string(tens[index]) + "-" + string(ones[x]);
} else
asString = unk;
char *result = (char*)malloc(asString.length());
memcpy(result, asString.c_str(), asString.length());
return result;
}
я просто сделал некоторые исследования и обнаружил, что ^ P является Escape-кодом Data Link (DLE). Я до сих пор не знаю, как его ввести. Как моя логика numword.cpp добавляет его? Куда я иду не так?
Я понял мою дилемму! Управляющий символ был артефактом из-за того, что я не был нулевым, прерывая мою строку из метода words. С тех пор я добавил нулевой терминатор, и проблема ушла. (Пожалуйста, не упоминайте о моих очевидных утечках памяти, я переучиваюсь!)
Обновленный метод слова:
const char * numword::words(uint64_t num) const {
std::string asString;
if(num < 20)
asString = string(ones[num]);
else if(num < 100){
int index = ((int)num/10)-2;
int x = ((int)num%10);
asString += string(tens[index]) + "-" + string(ones[x]);
} else
asString = unk;
char *result = (char*)malloc(asString.length());
memcpy(result, asString.c_str(), asString.length());
result[asString.length()] = '\0';
return result;
}
Других решений пока нет …