From bbbdd7ab8dfe1a7333d0c6e2344fee4ec44249ba Mon Sep 17 00:00:00 2001 From: Alexander Puck Neuwirth Date: Sat, 27 Apr 2024 22:23:11 +0200 Subject: [PATCH] Fix android buffer write carry over overflow char --- tyrant_optimize.cpp | 33 ++++++++++++++++++++------------- 1 file changed, 20 insertions(+), 13 deletions(-) diff --git a/tyrant_optimize.cpp b/tyrant_optimize.cpp index 030ce569..6e04254e 100644 --- a/tyrant_optimize.cpp +++ b/tyrant_optimize.cpp @@ -515,7 +515,7 @@ extern "C" JNIEXPORT void public: enum { - bufsize = 256 + bufsize = 512 }; // ... or some other suitable buffer size androidbuf() { this->setp(buffer, buffer + bufsize - 1); } @@ -527,32 +527,39 @@ extern "C" JNIEXPORT void *this->pptr() = traits_type::to_char_type(c); this->sbumpc(); } - return this->sync() ? traits_type::eof() : traits_type::not_eof(c); + sync_me(c); + return traits_type::not_eof(c); } - int sync() - { - int rc = 0; + + void sync_me(int overflow=0) { if (this->pbase() != this->pptr()) { - auto sss = std::string(this->pbase(), - this->pptr() - this->pbase()) - .c_str(); + char writebuf[bufsize+2]; + memcpy(writebuf, this->pbase(), this->pptr() - this->pbase() ); + writebuf[this->pptr() - this->pbase() ] = overflow; + writebuf[this->pptr() - this->pbase() + 1 ] = '\0'; + //auto sss = std::string(writebuf).c_str(); + ///* __android_log_print(ANDROID_LOG_DEBUG, "TUO_TUO", "%s", - sss); - jstring jstr = envv->NewStringUTF(sss); + writebuf); + //*/ + jstring jstr = envv->NewStringUTF(writebuf); jclass clazz = envv->FindClass("de/neuwirthinformatik/alexander/mtuo/TUO"); jmethodID messageMe = envv->GetMethodID(clazz, "output", "(Ljava/lang/String;)V"); envv->CallVoidMethod(objv, messageMe, jstr); - rc = 0; this->setp(buffer, buffer + bufsize - 1); } - return rc; + } + + int sync() + { + sync_me(0); + return 0; } char buffer[bufsize]; }; - // TODO should these news be deleted at some point? auto ao = new androidbuf(); auto ae = new androidbuf(); std::cout.rdbuf(ao);