Jump to content

  • Log In with Google      Sign In   
  • Create Account


Member Since 04 Feb 2008
Offline Last Active Today, 04:36 PM

#5292953 My Texture to HBITMAP function leaks and I don't know why...

Posted by fastcall22 on 22 May 2016 - 05:33 PM

// assuming std::vector<uint8_t> CDirectXWrapper::image_buffer;

image_buffer.resize(textureDesc.Width * textureDesc.Height * 4); // may or may not trigger realloc
uint8_t* destination = image_buffer.data();

#5292949 My Texture to HBITMAP function leaks and I don't know why...

Posted by fastcall22 on 22 May 2016 - 05:16 PM

For starters, you assign new[]’d memory to destination, but you don’t delete[] it. You may also consider using std::vector instead, so you only need to make an allocation for every time the source image grows, instead of allocating every frame.

#5291979 Trying to draw area from image fails.

Posted by fastcall22 on 16 May 2016 - 07:06 PM

Integer division: 1 / 3 is 0.

Consider using float literals wherever you expect to have a non-integer result:

float topborder    = (1.f / n)	  * (t - 1);
float bottomborder = 1 - ((1.f / n) * (n - t));

#5291898 Plane equation, + or - D

Posted by fastcall22 on 16 May 2016 - 11:44 AM

I tend to use +D, since it’s consistent with transformations and the like:

   0 = Ax + By + Cz + D
→  0 = Px*Nx + Py*Ny + Pz*Nz + D
→  0 = (Px,Py,Pz,1) dot (Nx,Ny,Nz,D)
→  0 = (float4(pt.xyz,1)) dot (float4(normal,distance))

#5291455 my C++ console 3D fps Game on Windows from scratch

Posted by fastcall22 on 13 May 2016 - 03:03 PM

Pretty cool! I’ve done something similar:

The color space was generated by combining a combination of foreground colors, background colors, and the three fill chars:

U+0032 ' ' 0%
U+2591 '░' 25%
U+2592 '▒' 50%
U+2593 '▓' 75%

After throwing out duplicates, there were about 360 unique colors. I then used voro++ to do fast nearest-neighbor lookup in 3d space.
Then the process was rendering to an 80x60 image, then transforming (r,g,b) to (foreground,background,char) and sending it to the GPU to render.

But now with Windows 10, the terminals are all different P:

#5289431 Optimization issue when using operator=

Posted by fastcall22 on 30 April 2016 - 10:28 AM

A good compiler should optimize away your entire test. Therefore, it is dangerous to make assumptions based on what you have here.

Redacted-- Frob is right, I forgot which board I was posting in.
Also, upon a second look, I realized that operator* is probably a typo of operator*=

My post is useless.

#5289040 "Could not find or load main class . . ."

Posted by fastcall22 on 27 April 2016 - 11:38 PM

Eh? I thought the proper way to launch jars was:

java -jar /path/to/jar

#5288483 Noob pointer question

Posted by fastcall22 on 24 April 2016 - 01:03 PM

Yes. It fails because there was not an allocation made for the address of a in the heap.

There are two general memory allocation strategies for objects depending on the lifetime of the objects: Stack and heap.

Stack memory is super quick as it only increments a stack pointer register, but binds the lifetime of the object to the scope it was created in; FILO ordering.

Heap memory is slower in that a registry of allocations must be traversed to find space for the object. Contrast to stack memory, objects can be deallocated at any time-- it is not bound to the scope it was created in. A contrived example would be a particle explosion effect, where the particles fizz out at random times.

There are other allocation strategies as well, such as pool allocations.

Whenever you use a reference or pointer, you must be mindful lifetime of the object it refers to. For instance, while your first example is valid, you must be careful not to use a after deleting pA, as the integer it once referred to no longer exists.

// simple demo of scopes and object lifetimes

struct Foobar { int x; };

int main() {
    Foobar f1;
    Foobar* pf1;
    Foobar* pf2;
    Foobar* pf3;

    /* 1: */ {
        Foobar f2;
        Foobar f3;

        /* 2: */ {
            Foobar f4;

            pf1 = &f4;
            pf2 = new Foobar;
            pf3 = pf1;
        } // f4 destroyed, pf1 and pf3 are invalid!

        // pf3->x = 5;  // Undefined behavior-- you’d be lucky to crash here
    } // f3, f2 destroyed

    delete pf2;  // foobar located at pf2 destroyed
} // f1 destroyed

#5288358 How do I link my DLLs to Code Blocks?

Posted by fastcall22 on 23 April 2016 - 06:00 PM

I tried copying the dll file directly into the folder my project is in, but the system just comes up with another missing dll to complain about...

You can use Dependency Walker to find all the DLLs you need, though I suspect you would only need to copy all the allegro DLLs.

There are mainly two places where the DLLs can be copied, the system32 directory, or the directory the program is in...

Actually, putting the DLLs into the system directory is the "correct thing"...

I disagree. According to Dynamic-Link Library Search Order for Desktop Applications, it also searches %PATH%, which I argue would be much cleaner than whoring out the system directory to third party libraries. Just add the allegro binary directory to %PATH% and you should be good to go.

I prefer copying (or hard-linking) the DLLs directly into the project directory, that way I can zip-and-deploy at any time. And also avoids the problem (for some libraries):
libwowamazing.dll: x86 or x64? debug or release? Linked against the mutli-threaded runtime or the static runtime?

#5287853 Negative ping? Or how do I sync time with client and server?

Posted by fastcall22 on 20 April 2016 - 03:51 PM

I suspect phone's time is not really correct.

Bingo. Clocks aren’t perfect, analog or digital. Think of a mechanical watch, always slipping either a few minutes ahead or behind over time. Digital clocks suffer the same problem, but on a much smaller scale (see: how can a digital clock drift in accuracy?). These days, your system periodically syncs the time with a nearby time server. This helps, but you still don’t have the exact time, unless you can you guarantee that all time servers have the exact same time.

What do you guys suggest?

Just ask the server what time it is, and adjust accordingly:

1. Client requests server time.
2. Client adjusts the value returned by the server, according to the time it took for that request to return.
3. Use this value as a baseline for all timestamps returned by the server, or repeat and average error.

#5287824 How to randomize a string variable

Posted by fastcall22 on 20 April 2016 - 01:41 PM

Important note: The system time in seconds is generally used to seed a new random number generator. Random number generators created within the same second will generate the same sequence of numbers.

Therefore, you shouldn’t make that “somewhere” in “create a new random number generator somewhere in your code” be immediately before its use, but rather, as a member variable initialized at load-time.

#5287729 std::sort corrupts my memory

Posted by fastcall22 on 20 April 2016 - 01:16 AM

SMyStruct::operator< is an invalid comparator. Write a well formed comparator for SMyStruct to fix:
bool SMyStruct::operator< ( const SMyStruct& m ) const {
    return std::tie(x, y) < std::tie(m.x, m.y); 

// or 

bool SMyStruct::operator< ( const SMyStruct& m ) const {
    if ( x < m.x )  return true;
    if ( x > m.x )  return false;
    if ( y < m.y )  return true;
    return false;

(Also note that this is the typical implementation of operator< for tuples and pairs.)

What compiler are you using? I can’t remember the last time anybody’s needed to add whitespace between right angle brackets in a template typename...

#5287692 Efficient click detection design

Posted by fastcall22 on 19 April 2016 - 04:53 PM

Either through elaborate GUI systems or something as simple by transforming the coordinates into an index into a list of items.

#5287647 FizzBuzz: Enterprise Edition!

Posted by fastcall22 on 19 April 2016 - 01:47 PM

For those not familiar with fizzbuzz: http://c2.com/cgi/wiki?FizzBuzzTest

There is an “enterprise implementation” of fizzbuzz available on GitHub: https://github.com/EnterpriseQualityCoding/FizzBuzzEnterpriseEdition

And even more amusing are its open issues:

Some of my favorites:
#141: *URGENT* *NEED HELP ASAP* I can't run this on my LG Optimus L9
#216: 6 Month Release Cycle
#214: Can we have a REST API?
#224: A Great Job Opportunity For You

Also: This looks like spam, but it’s not!!

Posting because these are hitting a little too close to home right now... :(

#5287403 HINSTANCE & HWND Corrupted when passed around functions

Posted by fastcall22 on 17 April 2016 - 10:53 PM

It seems to be a slicing of WinEventArgs due to a permissive interface. At the time of passing in args to func, an assignment from const WinEventArgs& to IEventArgs is made. Your callback then receives this copy and erroneously downcasts to WinEventArgs, and accesses invalid memory.

So the first step is to lock down your interface:
// How do I C++?
struct IEventArgs {
	IEventArgs() = default;
	~IEventArgs() = default;

	IEventArgs(const IEventArgs&) = delete;
	IEventArgs& operator = (const IEventArgs&) = delete;
The next step is to stop using const references on small data types. Not only will you need to be extremely mindful of the lifetimes of the objects they refer to, but you also incur double-indirection.
struct WinEventArgs : public IEventArgs
	WinEventArgs(const int a, const int b) : a(a), b(b) { }

	const int a;
	const int b;
The general rule of thumb is to pass-by-reference objects that are expensive to copy.
POD-types (int, float, WPARAM, LPARAM) and handles (such as HINSTANCE, HWND) are all integral-types. Pass-by-value*.
A vector<int> with 25000 elements? Pass-by-reference.

With the updated code above, Visual Studio reports:
std::function<void(IEventArgs)> func = std::bind(&Component::test, cmp, std::placeholders::_1);
func(args);  // C2280: 'IEventArgs::IEventArgs(const IEventArgs &)': attempting to reference a deleted function