Coder Social home page Coder Social logo

Comments (11)

kelunik avatar kelunik commented on June 8, 2024

This won't really help, since you still won't know which data the other and received. Data may have been written to the kernel's buffer but been sent.

from byte-stream.

ostrolucky avatar ostrolucky commented on June 8, 2024

It will help, I tested that. Just expose what information that class already has.

from byte-stream.

ostrolucky avatar ostrolucky commented on June 8, 2024

Why was this closed without explanation?

ResourceOutputStream checks if length of $data equals to value from fwrite. If it doesn't match, it repeats the write with unwritten data. If it doesn't succeed, it throws exception. I need to know what it tried to write last time.

from byte-stream.

kelunik avatar kelunik commented on June 8, 2024

I didn't intend to close this, yet. Probably mistyped on my phone.

from byte-stream.

trowski avatar trowski commented on June 8, 2024

As @kelunik pointed out, how useful is that information? When you write to a socket, you are only receiving confirmation that the OS has room in it's buffer for the data written. There is no guarantee that the client actually received that data.

from byte-stream.

ostrolucky avatar ostrolucky commented on June 8, 2024

That's all I need. If I don't send this data at all, it's definitely lost. If I do, there is high chance of this data reaching destination. Also not sure why are you talking about socket again, that's not the only resource. Do you have the same viewpoint for eg. files? fwrite returning > 0 not being guarantee for data being written to file? That seems kinda ridiculous to me. But once again, I don't understand how is not having guarantee of data reaching destination excuse for not handling known failure when sending it in the first place.

from byte-stream.

kelunik avatar kelunik commented on June 8, 2024

Re-opened, as it has been closed by the merge, but the merged commit has been reverted.

from byte-stream.

kelunik avatar kelunik commented on June 8, 2024

@ostrolucky ResourceOutputStream shouldn't be used for files, it just happens to work.

I'm not 100% opposed to exposing the information, but I think it is misleading and will not report what most people expect. I'd be cool to have information from the operating system which data has been ACKed by the receiving party, but we currently don't have that data.

from byte-stream.

kelunik avatar kelunik commented on June 8, 2024

I think it's a better idea to expose the unwritten bytes instead of the written chunk if we choose to expose that information, as with that information you can directly attempt a new write on reconnection or whatever your logic is.

from byte-stream.

ostrolucky avatar ostrolucky commented on June 8, 2024

That patch reported data that didn't succeed to be written. Turning it to int is more complicated from both sides - library and consumer. I need that data so I can repeat write.

from byte-stream.

kelunik avatar kelunik commented on June 8, 2024

I'm closing this in favor of amphp/file#35. We don't want to expose this information for every stream in this library, because for sockets it's generally misleading.

from byte-stream.

Related Issues (20)

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    🖖 Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. 📊📈🎉

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google ❤️ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.