<div><div dir="auto">LOL! Jordan, that&#39;s amazing! You would. I can&#39;t wait to play with that!</div></div><div dir="auto"><br></div><div dir="auto">With OSC over TCP, you could really do some longer distance communications with chuck. And it seems it would be pretty responsive, based on Mark&#39;s post.</div><div dir="auto"><br></div><div dir="auto">I guess just watch those state change messages on the receiving end unless you have two-way comms. Think like a web developer, hehe.</div><div dir="auto"><br></div><div dir="auto">I want to see some callbacks and generators in chuck now. I think Michael Heuer has that stuff in LiCK?</div><div dir="auto"><br></div><div dir="auto">M</div><div><br><div class="gmail_quote"><div dir="ltr">On Tue, Dec 4, 2018 at 12:08 Jordan Orelli &lt;<a href="mailto:jordanorelli@gmail.com">jordanorelli@gmail.com</a>&gt; wrote:<br></div><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex"><div dir="ltr"><div dir="ltr"><div dir="ltr"><div dir="ltr">ok, I had a little time to look at this, so I wrote you a simple proxy server in Go: <a href="https://github.com/jordanorelli/tuntun" target="_blank">https://github.com/jordanorelli/tuntun</a></div><div dir="ltr"><br></div><div>there&#39;s a binary release here if you want to just have a downloadable binary to check it out:<a href="https://github.com/jordanorelli/tuntun/releases" target="_blank">https://github.com/jordanorelli/tuntun/releases</a></div><div><br></div><div>and there&#39;s an example of how you&#39;d use it from Chuck here: <a href="https://github.com/jordanorelli/tuntun/blob/master/ex/ex.ck" target="_blank">https://github.com/jordanorelli/tuntun/blob/master/ex/ex.ck</a></div><div><br></div><div>this is a pretty straightforward proxying server to write. If you&#39;re not familiar with writing network servers, this is a good entry-level project for learning about it.</div><div><br></div><div>Chuck&#39;s subprocess facilities are, ... well, pretty weird. It doesn&#39;t seem like you get the pid of the spawned process; there&#39;s no way to signal it, so there&#39;s no way to kill it from Chuck. This example leaves you with a zombie process.</div><div><br></div><div>I&#39;m very confused as to how it operates internally, because it blocks the entire Chuck VM ... <i>unless </i>you stick an ampersand at the end of your command, which seems to put the job in the background. It ... it kinda looks like it&#39;s calling exec to exec a bash shell in the <i>current </i>process? I&#39;m ... a bit baffled by the behavior, to be honest, but I found a way to work it out.<br></div><div><br></div><div>Running it this way means that Chuck launches the proxying server for you and can tell the proxying server the ports to use. You could also run the server yourself outside of Chuck to not have to deal with the weirdness of Chuck&#39;s subprocessing facilities.</div><br></div></div></div><br><div class="gmail_quote"><div dir="ltr">On Tue, Dec 4, 2018 at 10:59 AM Mark Cerqueira &lt;<a href="mailto:mark.cerqueira@gmail.com" target="_blank">mark.cerqueira@gmail.com</a>&gt; wrote:<br></div><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex"><div dir="ltr"><div dir="ltr"><div dir="ltr">Roger Dannenberg did some real-time music work and compared UDP and TCP. His findings may surprise you! See 4.2 UDP vs. TCP here: <a href="https://www.cs.cmu.edu/~rbd/papers/icmc01aura.pdf" target="_blank">https://www.cs.cmu.edu/~rbd/papers/icmc01aura.pdf</a> tl;dr - he ended up going with TCP with some tweaks to make it more timely.</div><div dir="ltr"><br></div><div>Cheers!</div><div><br></div><div>mc</div></div></div><br><div class="gmail_quote"><div dir="ltr">On Sun, Dec 2, 2018 at 12:47 PM Jordan Orelli &lt;<a href="mailto:jordanorelli@gmail.com" target="_blank">jordanorelli@gmail.com</a>&gt; wrote:<br></div><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex"><div dir="ltr"><div>I&#39;m like ... 80% sure that there&#39;s no TCP-handling facilities built in, but I may be wrong here. If there is, I surely don&#39;t know about it.</div><div dir="ltr"><br></div><div dir="ltr">Can you tell us a little more about your use case?</div><div dir="ltr"><br></div><div dir="ltr">The design goals of TCP and ChucK are very different with respect to <i>time</i>. ChucK is designed around guarantees about time and timeliness. TCP is not designed around timeliness or latency in general: TCP is designed around guarantees about ordering (messages always appear in order) and delivery (messages are guaranteed to be delivered). Since every byte sent over a TCP socket has to be eventually acknowledged, and all bytes have to be processed in order, a stall in the network (a normal occurrence) could mean later messages being delayed, much like a traffic jam. It&#39;s not possible to have timing <i>guarantees </i>with TCP.<br><div><br></div><div>I&#39;m not sure how to find it in the source code, but maybe someone else here knows: does calling Std.system create a new shell process for each invocation? That would be a fairly inefficient way to go about things. Also since you&#39;re piping to another process, that&#39;s a new netcat process for each invocation (so it&#39;s either one or two processes per invocation), and a new TCP socket for every invocation. TCP is <i>especially slow </i>at <i>the very beginning of communication.</i></div><div><br></div><div>If I were in your shoes, I would probably write a separate program that acts as a server and serves an OSC-based protocol. This server would take your messages as OSC and translate them and then forward them to the intended recipient over just one TCP connection and continue to use that one connection the whole time. It may or may not respond to your ChucK program over OSC, depending on whether you want the ChucK program to get responses to its requests (probably not?).</div><div><br></div></div></div><br><div class="gmail_quote"><div dir="ltr">On Sat, Dec 1, 2018 at 1:25 PM mario buoninfante &lt;<a href="mailto:mario.buoninfante@gmail.com" target="_blank">mario.buoninfante@gmail.com</a>&gt; wrote:<br></div><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">
  
    
  
  <div bgcolor="#FFFFFF" text="#000000">
    <p>Hi,</p>
    <p><br>
    </p>
    <p>It seems like accessing the shell and use &quot;netcat&quot; (on Unix) is a
      possible solution. Quite an <i>exotic</i> workaround but better
      than nothing I&#39;d say.</p>
    <p>Something like that seems to work:</p>
    <p><i>// run ChucK with &quot;--caution-to-the-wind&quot;</i><i><br>
      </i><i><br>
      </i><i>&quot;echo -ne &#39;&quot; =&gt; string prefix;</i><i><br>
      </i><i>&quot;&#39; | netcat 127.0.0.1 3333 &quot; =&gt; string suffix;  //
        netcat &lt;target ip&gt; &lt;target port&gt;</i><i><br>
      </i><i><br>
      </i><i>while(true)</i><i><br>
      </i><i>{</i><i><br>
      </i><i>  Math.random2(0,127) =&gt; int r;</i><i><br>
      </i><i>  prefix + Std.itoa(r) + suffix =&gt; string msg;</i><i><br>
      </i><i>  Std.system(msg);</i><i><br>
      </i><i><br>
      </i><i>  second =&gt; now;</i><i><br>
      </i><i>}</i></p>
    <p><i></i><br>
    </p>
    <p>Please, let me know if anyone has a better solution.<br>
    </p>
    <p><br>
    </p>
    <p>Cheers,</p>
    <p>Mario<br>
    </p>
    <div class="m_-2296059746945903111m_-1842455255522013405m_587405356053983566m_-3928248464589800815moz-cite-prefix">On 01/12/2018 18:04, mario buoninfante
      wrote:<br>
    </div>
    <blockquote type="cite">Hi,
      <br>
      <br>
      <br>
      I also tried opening a file in /dev/tcp/&lt;target
      ip&gt;/&lt;target port&gt;, but it didn&#39;t work. I&#39;m on Ubuntu
      16.04. Any idea?
      <br>
      <br>
      <br>
      Cheers,
      <br>
      <br>
      Mario
      <br>
      <br>
      <br>
      On 30/11/2018 16:52, Mario Buoninfante wrote:
      <br>
      <blockquote type="cite">Hi,
        <br>
        <br>
        Does anyone know if it&#39;s possible to use TCP instead of UDP in
        ChucK?
        <br>
        <br>
        Cheers,
        <br>
        Mario
        <br>
      </blockquote>
      <br>
    </blockquote>
    <pre class="m_-2296059746945903111m_-1842455255522013405m_587405356053983566m_-3928248464589800815moz-signature" cols="72">-- 
Electronic Musician, Creative Coder, QA Engineer
<a class="m_-2296059746945903111m_-1842455255522013405m_587405356053983566m_-3928248464589800815moz-txt-link-freetext" href="https://vimeo.com/creativecodingsalerno" target="_blank">https://vimeo.com/creativecodingsalerno</a>
<a class="m_-2296059746945903111m_-1842455255522013405m_587405356053983566m_-3928248464589800815moz-txt-link-freetext" href="http://mbuoninfante.tumblr.com/" target="_blank">http://mbuoninfante.tumblr.com/</a>
<a class="m_-2296059746945903111m_-1842455255522013405m_587405356053983566m_-3928248464589800815moz-txt-link-freetext" href="https://github.com/mariobuoninfante" target="_blank">https://github.com/mariobuoninfante</a>
<a class="m_-2296059746945903111m_-1842455255522013405m_587405356053983566m_-3928248464589800815moz-txt-link-freetext" href="https://bitbucket.org/mariobuoninfante/" target="_blank">https://bitbucket.org/mariobuoninfante/</a></pre>
  </div>

_______________________________________________<br>
chuck-users mailing list<br>
<a href="mailto:chuck-users@lists.cs.princeton.edu" target="_blank">chuck-users@lists.cs.princeton.edu</a><br>
<a href="https://lists.cs.princeton.edu/mailman/listinfo/chuck-users" rel="noreferrer" target="_blank">https://lists.cs.princeton.edu/mailman/listinfo/chuck-users</a><br>
</blockquote></div>
_______________________________________________<br>
chuck-users mailing list<br>
<a href="mailto:chuck-users@lists.cs.princeton.edu" target="_blank">chuck-users@lists.cs.princeton.edu</a><br>
<a href="https://lists.cs.princeton.edu/mailman/listinfo/chuck-users" rel="noreferrer" target="_blank">https://lists.cs.princeton.edu/mailman/listinfo/chuck-users</a><br>
</blockquote></div>
_______________________________________________<br>
chuck-users mailing list<br>
<a href="mailto:chuck-users@lists.cs.princeton.edu" target="_blank">chuck-users@lists.cs.princeton.edu</a><br>
<a href="https://lists.cs.princeton.edu/mailman/listinfo/chuck-users" rel="noreferrer" target="_blank">https://lists.cs.princeton.edu/mailman/listinfo/chuck-users</a><br>
</blockquote></div>
_______________________________________________<br>
chuck-users mailing list<br>
<a href="mailto:chuck-users@lists.cs.princeton.edu" target="_blank">chuck-users@lists.cs.princeton.edu</a><br>
<a href="https://lists.cs.princeton.edu/mailman/listinfo/chuck-users" rel="noreferrer" target="_blank">https://lists.cs.princeton.edu/mailman/listinfo/chuck-users</a><br>
</blockquote></div></div>-- <br><div dir="ltr" class="gmail_signature" data-smartmail="gmail_signature">Michael Clemow<br>Artist/Composer/Sound Designer<br><a href="http://michaelclemow.com">http://michaelclemow.com</a><br></div>