venerdì 5 novembre 2010

RVM passo passo

Seguendo le istruzioni qui sono riuscito ad avere diversi ambienti ruby coesistenti

Istallazione

1) $ bash < <( curl http://rvm.beginrescueend.com/releases/rvm-install-head )

Operazioni post installazione

2) Check librerie necessarie come da messaggio presentato

# For RVM
rvm: bash curl git

# For JRuby (if you wish to use it) you will need:
jruby: aptitude install curl sun-java6-bin sun-java6-jre sun-java6-jdk

# For Ruby (MRI & ree) you should install the following OS dependencies:
ruby: aptitude install build-essential bison openssl libreadline5 libreadline5-dev curl git zlib1g zlib1g-dev libssl-dev libsqlite3-0 libsqlite3-dev sqlite3 libxml2-dev

ruby-head: git subversion autoconf

# For IronRuby (if you wish to use it) you will need:
ironruby: aptitude install curl mono-2.0-devel


3) Modifiche .bashrc

a fine file:

[[ -s "$HOME/.rvm/scripts/rvm" ]] && . "$HOME/.rvm/scripts/rvm" # This loads RVM into a shell session.

e modificato dove si trovasse la forma '&& return' come da istruzioni modifcanso come
if [...] then ;
code
fi


4) chiusura console

5) prova con
$ type rvm | head -n1
rvm è una funzione


Utilizzo

rvm install 1.9.2
rvm 1.9.2 --default # per rendere definitivo il cambio
rvm info
rvm system --default # per tornare a ruby standard



UPDATE

per alcune librerie può essere che serva una ricompilazione sotto ubuntu per ogni ambiente come riportato qui

venerdì 23 luglio 2010

Rails + Gmail con ruby 1.8.7

Un semplice How-to per fornire un applicazione Rails (2.3.x) del servizio di invio di mail
In particolare si suppone che esistano degli utenti User con attibuto User.username per testare l'interazione con l'applicazione

1) il mailer model "notifier"
Il primo passo è la creazione di un controller per l'invio delle mail

$ script/generate mailer Notifier
exists app/models/
create app/views/notifier
exists test/unit/
create test/fixtures/notifier
create app/models/notifier.rb
create test/unit/notifier_test.rb


crea il model notifier.rb e la cartella nelle viste notifier che conterrà le viste ovvero i modelli dei testi delle mail che manderemo

2)Il metodo"notification"
Bisogna quindi creare il metodo in /models/notifier.rb


class Notifier < user =""> user)
def notification(user)
recipients "myname@gmail.com"#user.email
from "myname@gmail.com"
subject "New account information"
body (:user => user)# "account" => recipient
content_type "text/html"
end
end


:user passato nel body rende disponibile la variabile @user nella vista che andremo a creare per il testo della mail

3) Il testo della mail
creiamo il file /views/notifier/notification.html.erb

Hi <%= @user.username %>,
Thanks for joining our service! Please check back often.


in cui @user è l'utente che abbiamo passato per argomento precedentemente

4) Modifichiamo le impostazioni di invio

modifichiamo il file /config/environments/developments.rb

ActionMailer::Base.smtp_settings = {
:enable_starttls_auto => true,
:address => "smtp.gmail.com",
:port => 587,
:authentication => :plain,
:domain => "myname@gmail.com",
:user_name => "myname@gmail.com",
:password => "mynamepassword",
}
config.action_mailer.raise_delivery_errors = true
config.action_mailer.delivery_method = :smtp


abbiamo completato le modifiche per testarle lanciamo la console con

script/console
Loading development environment (Rails 2.3.5)
>>

Quindi utilizziamo il methodo deliver per inviare la mail

>> Notifier.deliver_notification User.first
>> #TMail::Mail port=#TMail::StringPort:id=0x..fdb3d0cc4>
bodyport= #TMail::StringPort:id=0x..fdb3cf9d2
>>


Mail inviata e ricevuta

martedì 13 luglio 2010

Istallazione CMapTools in Ubuntu

Due dritte per l'installazione di CMapTolls in ubuntu
  • registrarsi con una mail
  • scaricare il file bin
creare la cartella radice in /opt/
  • cd /opt
  • sudo mkdir IHMC_CmapTools
rendere il file bin scaricato eseguibile
  • chmod +x LinuxCmapTools_v5.03_04-07-09.bin
Installare il programma
  • sudo ./LinuxCmapTools_v5.03_04-07-09.bin
    
    Preparing to install...
    Extracting the JRE from the installer archive...
    Unpacking the JRE...
    Extracting the installation resources from the installer archive...
    Configuring the installer for this system's environment...
utilizzando il tool di installazione avanzata è possibile personalizzare le opzioni in particolare specificare come directory radice /opt/IHMC_CmapTools precedentemente creata.

Se si vuole avere il link al programma basta creare un lanciatore che faccia riferimento al file
/opt/IHMC_CmapTools/bin/CmapTools

Una icona adatta la si può trovare a questo indirizzo

Scaricata l'icona per avere il lanciatore basta seguire le semplici istruzioni ipotizzando di trovarsi con il terminale nella cartella dove si è scaricata l'icona:
  • sudo cp CmapTools48px.gif /usr/share/pixmaps/
  • cd /usr/share/pixmaps/
  • sudo chown root:root CmapTools48px.gif
  • sudo chmod u+rw CmapTools48px.gif
  • cd /usr/share/applications/
  • sudo touch cmaptools.desktop
  • sudo gedit cmaptools.desktop
aggiungendo il seguente contenuto

[Desktop Entry]
Version=1.0
Name=CMapTools
Name[it]=CMapTools
Comment=Conceptual maps
Comment[it]=Mappe concettualil
GenericName=CMapTools
GenericName[ca]=CMapTools
Encoding=UTF-8
Exec=/opt/IHMC_CmapTools/CmapTools
Terminal=false
Icon=/usr/share/pixmaps/CmapTools48px.gif
Type=Application
MimeType=application/x-cmaptools
Categories=Application;Office;
Si ha così il lanciatore disponibile all'uso