You need to review the source in the openjdk to see how the lazy evaluation is performed. It should translate fairly easily.
Good luck ! > On Nov 13, 2018, at 12:54 AM, Iván Corrales Solera > <ivan.corrales.sol...@gmail.com> wrote: > > > Hey Robert, > > > Thanks you so much for your comments. > > Yeah, actually I got background developing with other languages such as Java > or Javascript or Python and actually the idea of creating Koazee is mainly > produced by my experience with Streams in Java or the map reduce in > Javascript. Anyway I haven't coded in Java in las 2 years so I will review > the link that was provided by you in order to check the Java API. > > Thanks > > >> On Tuesday, November 13, 2018 at 2:28:44 AM UTC+1, robert engels wrote: >> You can pretty much look at the Java8 streams source (from OpenJDK) and port >> it to Go. It would need to use interface{} or reflect - the former probably >> being faster, but both wouldn’t have the type safety - but I think the code >> would translate pretty easily. Still with IntStream, etc. you could get some >> of the the type safety back. >> >> https://docs.oracle.com/javase/8/docs/api/java/util/stream/Stream.html >> >> >> >> > On Nov 12, 2018, at 5:51 PM, Bakul Shah <ba...@bitblocks.com> wrote: >> > >> > >> > >> >> On Nov 12, 2018, at 9:53 AM, ivan.c...@bbva.com wrote: >> >> >> >> Hey Bakul again, >> >> >> >> I've been having a look at kona, and the project looks so good, I will >> >> look in deep trying to get some good ideas as you recommend me, >> > >> > Let me know (off-list) if you need help in deciphering things in kona. >> > >> >> In regards to the code generation, I've never done to be honest, but >> >> obviously the performance should be better. By the way, @Marko_Ristin >> >> created an issue asking for some performance testing. I think I will face >> >> this issue before considering code generation. But in case of the >> >> performance wasn't good at all, for sure that I consider your suggestion >> >> about generate the code >> > >> > Yes, this may not simple.... >> > >> >> And, what you mean when say "arbitrary streams (e.g. something built on >> >> top of channels)?" Sorry for my bad understanding, Thanks in advance >> > >> > To me a "stream" can be arbitrarily long and may grow while you are >> > operating on it. For example C's stdin, stdout etc. That means you >> > can't always operate on a "whole" string all at once as you can >> > with arrays. But many of the functions that operate on arrays are >> > useful with real streams. For example, a service may be generating >> > a stream of request log records. You may want to analyze these logs >> > for a given time period and may be create a graph. E.g. you may >> > have a pipeline like >> > >> > MakeStream(requestLogStream). >> > StartAt(date1). >> > EndBy(date2). >> > GroupBy(requestorIP). >> > Each(Count). >> > ... >> > >> > Here GroupBy may generate a stream of streams. Note: I am just >> > sketching the idea; there are many holes here. >> > >> > The idea is you can slice and dice these streams in various ways >> > to make sense of your data. Basically you are building unix like >> > pipelines but they are typed and you are not constrained by shell >> > syntax. >> > >> > This will be non-trivial but can be a very useful package. >> > >> > >> >> >> >> El lunes, 12 de noviembre de 2018, 12:17:12 (UTC+1), Bakul Shah escribió: >> >> On Nov 11, 2018, at 11:27 AM, Iván Corrales Solera >> >> <ivan.corra...@gmail.com> wrote: >> >>> >> >>> Hey guys, last weeks I've been working on Koazee and I just released a >> >>> very first version Titi, v0.0.1 . >> >>> >> >>> Koazee is a golang library inspired in Lazy evaluation and functional >> >>> programming that provides us a rich set of operations that can be done >> >>> over arrays. If you like the clean code and the functional programming >> >>> I am sure you enjoy it! >> >>> >> >>> >> >>> Documentation is hosted http://wesovilabs.com/koazee/ >> >>> >> >>> And the full code can be found on Github, >> >>> https://github.com/wesovilabs/koazee >> >>> >> >>> Any feedback or recommendation will be appreciated! >> >> >> >> Very nice! I like the clean interface. >> >> >> >> Some comments: >> >> >> >> - Can this handle arbitrary streams (e.g. something built on top of >> >> channels)? >> >> That would make a nice extension! >> >> - You may wish to look at k3 (open source version @ >> >> https://github.com/kevinlawler/kona) >> >> In particular https://github.com/kevinlawler/kona/wiki#verbs >> >> There are some additional functions (verbs) and higher order functions >> >> (adverbs) >> >> that may be of interest and will fit in nicely within your framework. >> >> PDFs of K 2.0 User and Reference manuals (listed under links) have much >> >> more detail. >> >> - May be you can provide another interface that *generates* Go code >> >> instead of >> >> executing it! If it can be made to generate more efficient code, devoid >> >> of >> >> reflect. >> >> >> >> >> >> "Este mensaje está dirigido de manera exclusiva a su destinatario y puede >> >> contener información privada y confidencial. No lo reenvíe, copie o >> >> distribuya a terceros que no deban conocer su contenido. En caso de >> >> haberlo recibido por error, rogamos lo notifique al remitente y proceda >> >> a su borrado, así como al de cualquier documento que pudiera adjuntarse. >> >> >> >> Por favor tenga en cuenta que los correos enviados vía Internet no >> >> permiten garantizar la confidencialidad de los mensajes ni su transmisión >> >> de forma íntegra. >> >> >> >> Las opiniones expresadas en el presente correo pertenecen únicamente al >> >> remitente y no representan necesariamente la opinión del Grupo BBVA." >> >> >> >> "This message is intended exclusively for the adressee and may contain >> >> privileged and confidential information. Please, do not disseminate, copy >> >> or distribute it to third parties who should not receive it. In case you >> >> have received it by mistake, please inform the sender and delete the >> >> message and attachments from your system. >> >> >> >> Please keep in mind that e-mails sent by Internet do not allow to >> >> guarantee neither the confidentiality or the integrity of the messages >> >> sent." >> >> >> >> >> >> -- >> >> You received this message because you are subscribed to the Google Groups >> >> "golang-nuts" group. >> >> To unsubscribe from this group and stop receiving emails from it, send an >> >> email to golang-nuts...@googlegroups.com. >> >> For more options, visit https://groups.google.com/d/optout. >> > >> > -- >> > You received this message because you are subscribed to the Google Groups >> > "golang-nuts" group. >> > To unsubscribe from this group and stop receiving emails from it, send an >> > email to golang-nuts...@googlegroups.com. >> > For more options, visit https://groups.google.com/d/optout. >> > > -- > You received this message because you are subscribed to the Google Groups > "golang-nuts" group. > To unsubscribe from this group and stop receiving emails from it, send an > email to golang-nuts+unsubscr...@googlegroups.com. > For more options, visit https://groups.google.com/d/optout. -- You received this message because you are subscribed to the Google Groups "golang-nuts" group. To unsubscribe from this group and stop receiving emails from it, send an email to golang-nuts+unsubscr...@googlegroups.com. For more options, visit https://groups.google.com/d/optout.