ponedeljek, 18. marec 2013

Git 'vejenje' (git branching)

Ker je za delo (tudi samostojno delo!) branching tako zelo uporabna metoda sem se odločil , da spišem tale kratek potek dela.


Teorija gre tako:
Programer se loti nekega spreminjanja kode za katerega pa ne ve, če bo sploh uporaben. Recimo, da hočete v vaš program dodati možnost izvoza podatkov v Libre Office.
Zato namesto da pišete v MASTER repo raje naredi novo vejo (branch), ki jo poimenuje po spremembi, ki jo želiote izvesti. Torej nekako tako:

Git checkout -b libreOffice

-b je za branch

V ukazni lupini boste zaznali spremembo:
namesto npr:
Hoornet@prostitute /c/Delo/MyWorkDir (master)

Bo sedaj 
Hoornet@prostitute /c/Delo/MyWorkDir (libreOffice)

Git vam tako sporoča na kateri veji se trenutno nahajate. Preskok je u šubu. Pri kreaciji nove veje to pomeni, da imate še vedno na voljo vso kodo od prej a lahko sedaj bolj ziheraško spreminjate kodo, saj manipulerate drugo vejo. V kateremkoli trenutku se lahko vrnete na prejšnje satanje.
Ko ste končali s 'pod-projektom' se odločite ali boste prelili spremembe v master ali ne. V primeru da je šlo vse ok delujte tako:

Najprej skočite nazaj na master z 
Git checkout  master

V trenutku boste nazaj v stanju pred vsemi spremmbami (t.j. v zadnjem stanju pred skokom v novo vejo). Sedaj lahko v master (t.j. v vejo v kateri se trenutno nahajate) zmixate prej ustvarjeno vejo z:
Git merge libreOffice

S tem ukazom ste vse spremembe, ki ste jih ustvarili v novi veji z imenom libreOffice zlili skupaj v default vejo (master).
Če hočete lahko sedaj pobrišete odrabljeno vejo z 
Git branch -d libreOffice
Lahko pa jo seveda pustite pri meru za eventualno vrnitev?! Eh! niti ne :) Rape its ass out


ponedeljek, 25. februar 2013

1) Rails for assholes - kako slediti 'projektu' na github

Github.com 

ali 

"What the fuck he wants from us now?!?"


Premisa: ok. Recimo, da si len človek :)


In recimo, da si tok len, da se ti ne da brat vsega sranja, ki ga napišem v blog (totalno štekam, jest tud nebi bral. Kav si ta Hoornet sploh misle da je. Idiot debiln! Mah.. pustmo to...) in bi se predvsem rad naučil vsaj nekaj Rails programiranja (nice try asshole! You should be more clever and choose a different blog if you are serious. Don't you see that Hoornet is just full of shit?!). Skratka zanima te predvsem koda...

Zato sem v svojem vsemogočnem, sočutju do tebe zastavil projekt (phahahaha! P... p... pr... projekt? hahaha) po delih. In to ne samo v obliki postov, ampak tudi v obliki paralelnih objav git tagov/branchov (whatever!) z imeni oz. številkami posta. Tako boš lahko (če bo seveda tale Hoornet sploh objavil naslednji post. Kreten!) preprosto sledil z do tistega trenutka narejenim projektom.
V ta namen bom uporabil že pridobljeno znanje (yeah right!) kontrole kode - GIT! Kot svoj server sem si izbral github, ki je za open source projekte (javne objave) đabe!!!


--------------

 Postopek

Postopek?

Meh...


Tako imaš sedaj dve možnosti (poleg seveda tiste , da vso kodo preprosto pretipkaš sam. Ampak to ne paše pod zgornjo premisa, kajne? Hehe! Đerkl!):
1)
Vsakič posebej narediš mapo in za vsak moj git push narediš najprej:
 git clone https://github.com/Hoornet/hoornet_sample_app.git
nato po
 git checkout branch_veselega_idiota

ali pa (in to pot priporočam tudi osebno)

2)
a) se registriraš na github.com (itak ti zna prit tale site prav še v prihodnje. Je kratko malo the best on the market!)
b) greš na moj projekt: https://github.com/Hoornet/hoornet_sample_app in klikneš FORK the project. S tem, dobiš svojo kopijo.
c) To kopijo potem kloniraš na svoj comp podobno kot zgoraj (la da seveda s svojim naslovom). Nato pa jo (kodo) lahko poljubno manipuliraš, pushneš gor svoje spremembe, in ko jaz spremenim svojo kodo, lahko te spremembe tudi potegneš na svoj repo. Mal mogoče prebereš navodila na githubu pa bo.



-----------------------

sobota, 23. februar 2013

0) Ruby on Rails for assholes (Ruby on Rails za kretene)

 Uvodnik


Če si želite, da vas nekdo zmerja in žali med tem ko se trudite učiti programiranja, potem ste prišli na pravo mesto!
Jaz, Hoornet, se bom posebej potrudil, da ti predam del znanja v skrajno nenavadni obliki. Zelo verjetno se ne boste naučili prav ničesar. V primeru da spravim v jok vsaj enega bralca bo moje delo opravljeno.
Zatorej pripravi svoj ego ščit in se odpravi na pustolovščino, ki pa se bo najbrž končala že danes saj se preveč len da bi napisal več kot nekaj vrstic na blog.
Moje ime je Hoornet in jaz sem znan po nesposobnosti!
Stopi v moj svet in postani neuporaben tudi sam!
In vseskozi si boš mislil da si se celo nekaj naučil! Ha! Zmota!

1) Inštaliraj Ruby on Rails

Oh, ti nesrečni človek, ki vstopaš v sobane kretena, uboga je tvoja glava.
Hoornet's proverb (17. century)
 
Kaže,da bom neki klikal po knjigi Ruby on Rails Tutorial 3.2....
Inštalacija poteka tako:
Enostavno poinštaliraj RailsInstaller, ki ga najdeš na, hmmm, http://railsinstaller.org
Za vse nadaljno delo v command promptu uporabljaj "Command Prompt with Ruby and Rails", ki ga najdeš pod Start->All programs->Railsinstaller


2) Ustvari sample_app

Najprej ustvari mapo kjer boš ustvaril rails app.
Sam uporabljam mapo RAILS za igranje s sabo :)
Do this:
D:\GitHubFiles\Learning\RAILS>rails new sample_app -T
      create
      create  README.rdoc
      create  Rakefile
      create  config.ru
      create  .gitignore
      create  Gemfile
      create  app
      create  app/assets/images/rails.png
      create  app/assets/javascripts/application.js
      create  app/assets/stylesheets/application.css
      create  app/controllers/application_controller.rb
      create  app/helpers/application_helper.rb
      create  app/views/layouts/application.html.erb
      create  app/mailers/.gitkeep
      create  app/models/.gitkeep
      create  config
      create  config/routes.rb
      create  config/application.rb
      create  config/environment.rb
      create  config/environments
      create  config/environments/development.rb
      create  config/environments/production.rb
      create  config/environments/test.rb
      create  config/initializers
      create  config/initializers/backtrace_silencers.rb
      create  config/initializers/inflections.rb
      create  config/initializers/mime_types.rb
      create  config/initializers/secret_token.rb
      create  config/initializers/session_store.rb
      create  config/initializers/wrap_parameters.rb
      create  config/locales
      create  config/locales/en.yml
      create  config/boot.rb
      create  config/database.yml
      create  db
      create  db/seeds.rb
      create  doc
      create  doc/README_FOR_APP
      create  lib
      create  lib/tasks
      create  lib/tasks/.gitkeep
      create  lib/assets
      create  lib/assets/.gitkeep
      create  log
      create  log/.gitkeep
      create  public
      create  public/404.html
      create  public/422.html
      create  public/500.html
      create  public/favicon.ico
      create  public/index.html
      create  public/robots.txt
      create  script
      create  script/rails
      create  tmp/cache
      create  tmp/cache/assets
      create  vendor/assets/javascripts
      create  vendor/assets/javascripts/.gitkeep
      create  vendor/assets/stylesheets
      create  vendor/assets/stylesheets/.gitkeep
      create  vendor/plugins
      create  vendor/plugins/.gitkeep
         run  bundle install
Fetching gem metadata from https://rubygems.org/...........
Fetching gem metadata from https://rubygems.org/..
Resolving dependencies...
Using rake (10.0.3)
...Your buudle is complete! Use `bundle show [gemname]` to see where a bundled gem is installed.
Komanda je več ali manj očitna. Edino kar je omembe vredno je -T
-T opcija namreč pomeni naj zgradi Rails app BREZ test direktorija.
Testov zaenkrat ne bom uporabljal zato -T

četrtek, 21. februar 2013

Čas je za Git

Dragi (edini) bralec bloga!
Naj te danes napotim k neverjetno uporabnemu orodju modernega razvijalca programja. 

Uvodnik z malo zgodovine

Gre za enega najpopularnejših orodij za source control. Pred leti smo gonili CVS. Kasneje smo spoznali zmoto in naveliko preheblal na SVN oz. Subversion, kot smo mu pravili ljubkovalno. Delal je dost ql za tiste čase, če si seveda zadovoljen z nujno povezavo s serverjem za vsako dodano spremembo.
Ampak pred pa leti je popizdil The Linus!
Ja, taisti midel, ki je izumil Linux in ki se je dnevno zgražal nad grozljivim delom, ki ga je opravljal. In sicer gre za managing kode za Linux!
Si lahko predstavljaš vso kramo, ki jo ta model dnevo poriva v Linuxov repozitorij!
In ko model za nameček naleti na licenčne omejitve source control sistema, ki ga je takrat uporabljal je bila jeba popolna!
Tip popizdi in se dela loti sam, In v 14 dneh rukne ven eno začetno  verzijo SCM-ja z imenom Git!
Iskaže pa se fa je zadeva tok ql in tok hitra in univerzalna, da jo kmalu posvojijo tudi druge veje open source communitya.
Npr. Ruby folk! In ker zadnje čase Ruby kle gonmo je edino prav da tudi git posvojimo.

 Enouporabniško delo z Git (brez badaljnih nakladanj)

Ok. Nočeš torej vedeti zakaj je Git tak zakon itd. Zanima te zgolj kako začet z delom čimprej.
You've come to the right place, asshole!

Install the damn fence (i mean git)

Najprej seveda rabiš poinštalirat sam git. Go here, jerk! And look around for the download, won't ya!
Windows idioti, kot jaz lahko grejo direkt na: http://git-scm.com/download/win
Ob času pisanja tega posta je bla vezija cca. 1.8.1
Skratka poinštaliraj git. Bili so časi, še nedavno tega (lani?) ko je bila inštalacija tega orodja malce zakomplicirana; prihajajoč iz Linuxa etc. Danes temu ni več tako. Predlagam pa da pokljukcate TrueType font, izberete "Run Git from win Command prompt" in drugo pustite pri meru. Če se odločite, da boste izbrali Easy verzijo, potem poklikajte še uni dve podopciji, t.j bash in Gui... :)


Prvi koraki...ali post inštalacija

Glede na to, da uporabljaš git prvič bi blo dobr povedat mu kdo za hudiča ti sploh si. To ti zna priti prav, ko bo treba kazati s prstom na druge, ko pride do zajbka v kodi:
"Kreten debiln od šefa! A ne vidiš kle! Kle ti kažem, kle, idiot! A ne vidiš kdo je podpisan pod commitom? A je to mogoče moje  ime? Prašam... Mislem sam rašam! A JE TO MOGOČE MOJE IME! Kaj piše kle?! Kle piše Janez Janša! A je men ime Janez Janša?
Ne! Men ni ime Janez Janša! In kaj piše kle? 
Kle piše Janez Janša!
Torej? Kdo je commitav ta del kode? 
A sm bil to jest?
Ne! To je bil Janez Janša!"
itd.
Skratka: There is enough blame to go arround :)
Pri vsakem commitu (to je zapisu stanja kode, kot je bilo v tistem trenutku) je zraven zapisan komentar avtorja commita in njegovo ime.
Do this:
$ git config --global user.name "Slovenec Brezkurcni"
$ git config --global user.email slovenec@brezkurcni.si
 
Zgornjo zadevo naklofaš v prompt samo enkrat, saj se zadeva (glej --global oznako) zapiše v tvoj user profil, nekje v .gitconfig dir.

Če hočeš prevert nastavitve do this:
git config --list
Ven bo vrgu neki podobnega kot:
core.symlinks=false
core.autocrlf=true
color.diff=auto
color.status=auto
color.branch=auto
color.interactive=true
pack.packsizelimit=2g
help.format=html
http.sslcainfo=/bin/curl-ca-bundle.crt
sendemail.smtpserver=/bin/msmtp.exe
diff.astextplain.textconv=astextplain
rebase.autosquash=true
user.name=Slovenec Brezkurcni
user.email=slovenec@brezkurcni.simerge.tool=kdiff3
mergetool.kdiff3.path=C:/Program Files/KDiff3/kdiff3.exe
diff.guitool=kdiff3
difftool.kdiff3.path=C:/Program Files/KDiff3/kdiff3.exe
difftool.kdiff3.cmd="C:/Program Files/KDiff3/kdiff3.exe" "$LOCAL" "$REMOTE"
core.editor="C:/Program Files/GitExtensions/GitExtensions.exe" fileeditor
core.autocrlf=true 

Seveda bo zadeva samo podobna. Zgornji izpis je bil izveden na kompu, ki ima zraven poinštaliran še
git extrension. Če ga hočeš ga maš kle, kjer si lahko kaj več o paketutudi prebereš.

Let's init my ...
Ok. Napredek! (če ti git ne dela c command promptu bi znalo bit dobr znova zagnat winse. Kaj češ, tehnologija prejšnjega tisočletja pač. Hehe. hehe. muahahhaha)
Do that:
1) 
 Start->All programs->Git->Git Bash

Evo ti slike:




2) Spizdi v mapo, katere vsebino (in struktoro) hočeš soravit pod verssion control (se sliš kot da ga daješ u jarem avtoritarne družbe). In ne pozabit da je bash, linux-like in ne windows-like (glej spodaj napako \ namesto / ):
Hoornet@HOORNET-PC ~
$ cd D:\GitHubFiles\BLOG
sh.exe": cd: D:GitHubFilesBLOG: No such file or directory
Hoornet@HOORNET-PC ~
$ cd D:/GitHubFiles/BLOG
Hoornet@HOORNET-PC /d/GitHubFiles/BLOG
$
Ok. Torej recimo da sem v željeni mapi. Čist vseen je, ali je mapa prazna alin pa že ima vsebino. Ko namreč začenemo komando:

 $ git init
Initialized empty Git repository in d:/GitHubFiles/BLOG/.git/
Hoornet@HOORNET-PC /d/GitHubFiles/BLOG (master)
$

smo omenjeno mapo in vse podmape z vsebino vred postavili v source control. Seveda lahko ignoriramo določene mapi, fajle ali tipe fajlov ampak o tem (morda?) drugič.

Če sedaj damo pregledat kaj vse je v mapi, bomo videli, da je git dodal novo mapo z imenom:
.git

V tej mapi IN SAMO V TEJ MAPI je vse kar se tiče vaše pravkar init-ane mape in njene vsebine (dejmo zej temu pravt kar samo mapa. Nanaša se na vse podmape in svo vsebino v njih). Git nima svoje mape v vsakem poddirekltoruiju kot ste navajeni ustrahovani SVN-jevci. Totalni zakon, kadar hgočete skopširat vse kar mate v mapi brez gitovega dela!!!
Pa dejmo prevrit kva je sedaj not v mojem primeru.
3) Do this:
$ ls -a
.  ..  .git  Git_time
Hoornet@HOORNET-PC /d/GitHubFiles/BLOG (master)
$
Kot vidiš je poleg moje podmape git_time noter še en dir z imenom .git
Še nekaj! Skoraj vse to lahko počnete v običajnem win promptu ampak ne boste videli sprotne informacije kot je:

Hoornet@HOORNET-PC /d/GitHubFiles/BLOG (master)
$


In to: IN COLOR!!!! Že v letu 2013 e.v.!

4) Git vsebuje komando status, ki nam vedno poda trnutno sliko. Do that:
$ git status


in boš dobil izpoved:
# On branch master
#
# Initial commit
#
nothing to commit (create/copy files and use "git add" to track)
Hoornet@HOORNET-PC /d/GitHubFiles/BLOG (master)
$
Kot nam da sam git vedeti trenutno še ne sledimo ničemur. Dejmo nardit en ruby file s katerim se lahko potem igramo:


Za primer sem izbral en file (kontroller) iz Rails applikacije.

5) Torej dodajmo file v sledilnik (za drugačen prikaz bom sedaj uporabljal običajni Win command prompt). Najprej status potem dodajmo, rubijev file in nato še nkrat preverimo status:

D:\GitHubFiles\BLOG>git status
# On branch master
#
# Initial commit
#
# Untracked files:
#   (use "git add <file>..." to include in what will be committed)
#
#       Git_time/
nothing added to commit but untracked files present (use "git add" to track)

D:\GitHubFiles\BLOG>git add .

D:\GitHubFiles\BLOG>git status
# On branch master
#
# Initial commit
#
# Changes to be committed:
#   (use "git rm --cached <file>..." to unstage)
#
#       new file:   Git_time/movies_controller.rb
#

D:\GitHubFiles\BLOG>
Štekaš?
Sedaj mam now file noter namenjen sledenju, toda da zapišem trenutno stanje moram storiti še nekaj: Commit s komentarjem spremembe.
6) Do this:
 D:\GitHubFiles\BLOG>git commit -m"začetni commit"
[master (root-commit) 53192ac] začetni commit
 1 file changed, 60 insertions(+)
 create mode 100644 Git_time/movies_controller.rb

D:\GitHubFiles\BLOG>
Če sedaj poizvem po statusu sledenih datotek dobim sledeč rezultat:
D:\GitHubFiles\BLOG>git status
# On branch master
nothing to commit, working directory clean

D:\GitHubFiles\BLOG>


Vse datoteke so torej shranjene v trenutnem stanju. Dajmo sedaj spremenit datoteko tako, da bom pobrisal 3 metode v fajlu:  


Preverimo sedaj status, da vidimo, če je git poštekal da sem premenil fajl:
D:\GitHubFiles\BLOG>git status
# On branch master
# Changes not staged for commit:
#   (use "git add <file>..." to update what will be committed)
#   (use "git checkout -- <file>..." to discard changes in working directory)
#
#       modified:   Git_time/movies_controller.rb
#
no changes added to commit (use "git add" and/or "git commit -a")


Aha! Git je zaznal spremembo. Recimo da smo sedaj vmes programirali in da je sedaj ta datoteka končana. Torej je čas za nov commit.  Postopek, ki ga nato ponavljam ob vsaki spremmbi, ki jo ohčem zapisati je:
D:\GitHubFiles\BLOG>git add .

D:\GitHubFiles\BLOG>git commit -m"odstranil odvečne metode"
[master f6f5754] odstranil odvečne metode
 1 file changed, 21 insertions(+), 60 deletions(-)
 rewrite Git_time/movies_controller.rb (82%)

D:\GitHubFiles\BLOG>

Na tak način imam zapisane vse verzije vseh fajlov in map.
O tem kako do dolečene verzije pa (morda) prihodnjič.

Za zdaj lahko rečem samo to:
Switch to git!

C ya!