Erlectricity: Hi Ruby, I’m Erlang.

May 8th, 2007

update: this pre-release is up and running on rubyforge:

sudo gem install erlectricity

As I said in my previous article, I’m very stoked about working with Erlang. Usually most forays into new languages mean new projects and new explorations: Erlang has been no different. I usually end up in some middle ground where I try to improve the current language I’m working in with the new language: With C# -> Ruby it was a code generator written in Ruby that produced the cookie cutter DALs that I was plagued with, and this time around I immediately started to gravitate towards interoperation between erlang and ruby.

I’m not the only one with this idea (I’ve never claimed to be original), with several others working on using JSON to bridge the gap. That is all well and good, but considering how good erlang is at expressing itself across networks, I’d rather see something closer to the erlang-way. And that is why I set about creating what I call Erlectricity.

Before I go further, a code sample is in order. The following code is a passthrough daemon to Tinder, (the Campfire API gem) that lets you post to campfire from erlang. Even more before I show you the code, here is the google code site: http://code.google.com/p/erlectricity/, with the source being: http://erlectricity.googlecode.com/svn/trunk/. And now…

The Ruby:

require 'rubygems'
require 'erlectricity'
require 'tinder'

domain, email, password, roomname = *ARGV campfire = Tinder::Campfire.new domain campfire.login email, password room = campfire.findroombyname room_name

receive do match(:speak, string(:comment)) do room.speak comment receive_loop end

match(:paste, string(:comment)) do room.paste comment receive_loop end end

room.leave if room

And some erlang to call it (i’m omitting some code, please see the tinderl.erl example in the source to see the code that enables the calls below):
tinder:start("thedomain", "myemail@gmail.com", "mypassword", "theroom"),
tinder:speak("hey, hey kids!"),
tinder:paste("Im Krusty the Klown!").
At first, this was going to be a JRuby layer over JInterface, the Java -> Erlang bridge. That was all well and good, and worked fine, but it had a major flaw: It was tied to JRuby, leaving out the majority of Rubyists. JRuby is super exciting, and I was super stoked the first time I got ruby running inside a prototype game using The JMonkey Engine, but I didn’t want to be the person to exclude. I decided at this initial stage to use the Erlang port system, a means of starting and communicating with a separate process. As a consequence, I implemented most of the Erlang distribution format. Why re-invent the wheel when erlang has termtobinary and binarytoterm? Plus, it’s fun investigating the Erlang distribution format, even though only a subset is used for termtobinary.

As an aside, one reason to re-implement termtobinary and its sibling is because of the limited nature of Erlang’s type system.

You’ll also notice in the example directory ‘gruff’: 2 hours of hacking invested into rendering Gruff graphs through Erlectricity. Below is a graph generated using the stat_writer example to graph memory usage while running ab against webtool:

This was as a response to Yariv, and his desire for a graphing library in erlang like gruff. The example isn’t by any means a real solution, merely a demostration that this could be a viable solution.

The goal of Erlectricity is two-fold: expose ruby code to erlang, such that erlang applications can take advantage of the breadth of ruby libraries, and secondly, expose the OTP to ruby such that fault-tolerant distributed systems will be easier to develop. Neither of those goals are realized in Erlectricity’s current form, but it is a good base to work from towards those goals. Also, the two examples included demonstrate the former, and I’m playing around with something meaningful to demonstrate the latter.

This post is already about 3-times too long, but let me real quickly describe the structure of an erlectric app on the ruby side. The programming model follows the concurrency model of erlang, so read up on how erlang processes messages if you get confused. I’ll also describe it in further detail in an additional post. So, the core of an app using erlectricity is the receive loop, which looks like:

receive do
  match(:hello, string(:yourname)) do
    send! :helloreceived, "You stink, #{yourname}"
    receiveloop
  end
  match(:goodbye){ }
end
The receive block says “get a message, blocking if there are none on the wire”. When a message is received in this state it is compared with each of the match blocks in turn. The match block in the example says “If the message looks like the symbol :hello, and a string, bind the string object to the variable yourname and run the block.” Normally, when receiving a message, the code would then jump out of the receive block, but since the return value of the match block is receiveloop, the program tries to process another message against the same supplied match blocks. You’ll also notice that if the process receives a message that is just the symbol :goodbye, the app will simply fall out of the receive loop.

Here are some tips if you would like to play around with Erlectricity:

  1. Email me if you have any trouble: nullstyle@gmail.com
  2. Pass strings as binaries to ruby. “haha” will come out as [104, 97, 104, 97] in ruby, but <<”haha”>> will come out as “haha” in ruby. See my comment above about the limited type system in erlang. I’ll make a separate post about this issue, because I want to talk more fully about why I made this choice.
  3. Make sure your port is created with the {packet, 4} and binary options. Creating a port with {packet, 2} will have your ruby process never receiving any messages. Not having binary responses enabled will cause trouble when you try binarytoterm to get the response. This is an area for further improvement.
  4. Its a good idea to include catch-all clauses while you are working out the interaction issues. It greatly sped up my debugging time when I had the program yell at me when I sent an improper message
I would like to do several things with Erlectricity. first of all I would like to remove the possibility of programmer error in as many places as possible. There isn’t much work to do in this regard on the ruby-side(as far as I can tell, feedback is always welcome), but the hoops you need to jump through on the erlang side should go away. I’m thinking about abstracting away the framework bits and creating a behavior that you can implement in a callback module, similar to how the OTP does things. Putting a layer on the erlang side between user code and the port will allow me to smooth out some of the type translation issues too.

You can install erlectricity with:

sudo gem install erlectricity --source http://gems.nullstyle.com/
I’m in process of opening up the rubyforge project, so you’ll be able to drop the –source in a couple days. Stay tuned for more info, examples, and improvements as time marches forward.

Share and Enjoy: These icons link to social bookmarking sites where readers can share and discover new web pages.
  • DZone
  • Digg
  • Reddit
  • del.icio.us
  • Blue Dot
  • StumbleUpon
  • Netscape
  • Ma.gnolia
  • Slashdot
  • Technorati
  • NewsVine
  • Netvouz

One Response to “Erlectricity: Hi Ruby, I’m Erlang.”

  1. Tim Carey-Smith Says:

    Hi there!

    You may or may not be aware that some of us have started a github network. If you visit http://github.com/mojombo/erlectricity and http://github.com/halorgium/erlectricity, you’ll see some of the changes we’ve made.

    I’m not sure if you’re into git, but it sure works well for random projects like this one!

Leave a Reply

parasite medications face wrinkles cialis approval treating chlamydia revatio efects colon cleaning buy discount viagra online buy xanax with no prescription cures for throat infection soma or valium ambien and side effects generic cheap viagra free phentermine medication skelaxin treatment for leukemia osteoporosis medication side effects cheap xanax without prescription skin fungal infection alcoholism medical treatment improve the appearance of skin pravachol online parasite infestation help for adhd ambien 10 cheap pain med how to use clomid aspirin soma dose cialis online cialis acne prescription gabapentin dosage skin swelling coreg buy vitamin a anti smoking buy extendaquin antibiotic herbs treating bipolar disorder levitra buy depression relief increased blood flow insomnia sleep problems generic cheap viagra viagra online cheap cialis advice test natural antibiotics discount medicines for pets scabies cure cheap order buy teeth whitening purchase viagra on line natural viagra products breast enlargement cheap bactrim xanax price asthma medication lexapro medicine med help online increase womens sex drive problems breathing how to stop smoking viagra cialis compare buy cialis online anxiety meds effective acne products buying ambien sexual power causes of chest pain diabetes treatment how to reduce high blood pressure where can i order phentermine arthritis therapy tamiflu flu buy plan b online herbs for breast growth phentermine without a perscription effects of ultram male body building chloramphenicol antibiotic hair loss products for men effects of allegra dogs health problems natural constipation remedies what are beta-blockers increasing breast size naturally canada over the counter antibiotics pharmacy top hair loss pharma kamagra profesional cialis big muscles cost of birth control arthritis help natural cure for erectile dysfunction natural eye drops legality of buying cialis online bactrim dosages medicine on line cheap viagra online prescription dog s health arthritis support reducing blood pressure canada drug store tablets to stop smoking best body building products hair loss treatment online lamictal drug atenolol interaction stopping smoking generic imitrex breast enhancer menopause cures women enhancement cat health info symptoms high blood pressure valium high pet medicine cheap phentermine without a prescription cat care safe place viagra online xanax by mail how to improve sleep cheap pfizer viagra cialis cod healthy pets avandamet body acne treatment cancer treatments buy vardenafil online blood pressure diet nexium prilosec vs how to white teeth ear infection symptoms hoodia weight loss abdominal pain symptoms ambien dosages scabies cure ciprofloxacin 500mg cheapest cialis uk how to stop hair loss valium without a prescription viagra from usa cialis without rx anti depression drugs treating urinary tract infection dark spot on skin pharmacy information us hiv treatment guidelines muscles pain relieve asthma cures tricor tablets breast cancer drugs purchase viagra online without prescription pain pregnancy relief weight loss how to where buy viagra health bone disorder celebrex generic tooth whitening california levitra buy levitra medicines to reduce heart rate sexual power drug lower blood pressure medication gonorrhea order prilosec online imitrex new weight loss drug celexa buy omega 3 best fat blockers relief from constipation buy alcoholism medications help sleep problems phentermine with hoodia beta-blocker med cialis best on-line drugstore stop premature ejaculation free home neck pain relief weight loss foods drug zyban how to reduce blood pressure buy griseofulvin without prescription online diazepam treatment of heart attacks levitra doses betablockers purchase levitra in canada pain behind knee shoulder pain gernic viagra how to make my teeth white order prilosec no prescription cialis online new breast cancer drug medication for high blood pressure dog thyroid cancer care cialis cod cat irritable bowel syndrome treating aids in africa discount erectile dysfunction medications tips for increasing breast size herpes varicella body building products clozapine medication levitra viagra cialis low price skin care tips flomax prescription xanax without perscription prescription drugs diuretics prescription new hair loss remedies citalopram 20mg buy weight loss product natural eye drops drug stores levitra 50mg teeth whitening california depression in men cialas on line buy generic depakote sex with levitra natural penis enlarger breast cost enhancement canada online pharmacy viagra light cure for pain coumadin information woman diet pills progesterone clomid discount viagra online building your body skin allergies relafen effectiveness omeprazole dosage tooth whitening california hair loss hair care information Buy Cialis Online breast enhancement products pills for acne weight loss drug doxycycline pregnant weight loss systems medical weight loss mass muscle skin disease cheap pain relief pain medications generic side effects medication to stop smoking levitra do for men xanax dosages older dog health prozac type 2 diabetes controlling high blood pressure promethazine cheapest carisoprodol persistent diarrhea phosphatidylserine complex remedies for stomach ulcers coumadin information how to lower blood pressure a reliever of arthritic pain rhinitis treatment beta blockers side effects discount cialis levitra viagra asthma treatments drugs for anxiety reason for high blood pressure actonel dosage aciphex how to buy viagra online no hangover blood pressure drug names prevacid online human parasite dogs weight discount vitamins supplements improving immune system how to increase fertility online xanax clozapine medication parkinson medications thyroid dogs alternative therapy for rheumatoid arthritis avodart prescription clomid prescription blood pressure treatment drugs acai berries phentermine with hoodia treating urinary tract infection weight loss vitamins causes of high blood pressure effects klonopin herpes medicine natural penis enlarger how to purchase cialis natural dog remedies cephalexin sinus viagra in mexico expected weight loss with phentermine asthma attack treatment valium no prescribtion treatment for high blood pressure buy paxil online cheap antibiotics online sildenafil 100mg healthy pet treats drugs weight loss muscle pain treatment how to improve sleep sleep disorder treatment zyrtec pills generic for zocor gonorrhea women symptoms diet supplements that work medication gonorrhea carisoprodol mg ambien doses acne tips ambien cost ulcers stomach generic imitrex spironolactone effects xenical mexico prescriptions male enhancements cure for high blood pressure neck muscle pain breast enhancement products new natural treatment for menopause symptoms heart failure drug therapy diabetes medical buy prescription drugs flomax generic buy viagra soft flavored buy lotrisone cream nutrition and bone health mirtazapine depression quit smoking programs cimetidine dose fertility in women bacteria producing antibiotics online viagra prescription online viagra buy periactin anti nausea medications gonorrhea cure nexium generic cheapest generic levitra natural pain cures lotensin buy ultram drug ramipril irritable bowel treatments pet health insurance weight loss products cheap hypnotherapy courses uk nexium generic type 2 diabetes metoprolol dose buy stromectol cialis buy online cephalexin prescription hypothyroidism treatments breast enlargement elevated blood pressure viagra online store safe pain reliever back medication on line osteoporosis exercises diazepam lorazepam discount viagra generic buy cabergoline revatio drug new depression treatments buy penisole dog health information drug list high blood pressure How To Buy Viagra cholesterol information diflucan otc blood pressure drug names medication metformin buy valium online cheap new depression treatments alternative hair loss cures penis enhancement pills cat health help drugs diet male sexual power diovan arthritis natural cure cheap cialis tadalafil dosage of valium enhancement breast buy viagra online cheap How Do I Order Viagra Online soma zolpidem dosage herpes drug arthritis natural cure zyban no prescription stroke treatment hyaluronic acid buy infection lung Viagra Cialis Online free hoodia treatment bacterial infections order phentermine levitra medicine care for a cat hyaluronic acid buy immune system supplement lanoxin generic atenolol withdrawal control of pain cheap fast valium ambien doses valium used symptoms of heart failure order bactroban buy cialis line natures antibiotic causes for high blood pressure cheap viagra online natural muscle and joint health different treatments of alcoholism buy viagra professional hair loss home remedy diuretic medication depression relief breast enhancer pills allergies online prescriptions viagra medication to stop smoking order flagyl depression relief beta blockers dangers of high blood pressure increasing penis size natural constipation remedies buy cheap tadalafil uk colon cleanes treatment for infertility stop smoking remedies how to white teeth where to order soma addictive ambien clomid sale new antibiotic drug help sleep problems buy discount viagra online