May 28th, 2008
Now Banshee 1.0 Beta 2 is released. If you want to try the music player in your ubuntu hardy box, you could add sources.list entry from banshee PPA team.
Open software sources (System > Administration > Software Sources). In Third-Party Software tab, click Add and paste the code below
1
| deb http://ppa.launchpad.net/banshee-team/ubuntu hardy main |
If you need the source, you could repeat the Add proccess, and paste this
1
| deb-src http://ppa.launchpad.net/banshee-team/ubuntu hardy main |
Close the Software Sources. Wait for a few moment while the software update your package database. Then open the terminal, and type
1
| sudo apt-get install banshee-1 |
Yes, use banshee-1. If you use banshee, you’ll get the old Banshee 0.13.2 from universe repository.
And, enjoy your new Banshee
May 27th, 2008
I created this tutorial because I was having a hard time finding good simple CodeIgniter + JQuery tutorial for newbie like me. The one I found, created by MR Forbes, is hard to understand and apparently isn’t working. Another one, pr0digy’s, is using Mootools for the AJAX framework.
So I decided to create my own CodeIgniter and JQuery tutorial based on pr0digy’s tutorial. I’m assuming you already know how to code using CodeIgniter. If you’re new to CodeIgniter, you need to find others tutorial first. The videos given in CodeIgniter’s site is a good start.
This tutorial is about creating simple CodeIgniter + database + ajax system. User will be shown a form to post a message. Then after he/she press the submit button, the system will save the message using ajax and then show the message. You could see the result first if you want.
Database
The first thing we need to do is creating a table to save the message. For this tutorial, We will use this:
1
2
3
4
5
| CREATE TABLE IF NOT EXISTS `messages` (
`id` tinyint(4) NOT NULL AUTO_INCREMENT,
`message` varchar(256) NOT NULL,
PRIMARY KEY (`id`)
) |
Controller
Then, we need to create a controller. My controller is named message. You could name your controller any name you like. After that, create 2 functions/methods, view and add.
view is used to get the default view and list of messages from the database. The codes are:
1
2
3
4
5
6
7
8
9
10
| function view($type = NULL)
{
// get data from database
$data['messages'] = $this->Message_model->get();
if ($type == "ajax") // load inline view for call from ajax
$this->load->view('messages_list', $data);
else // load the default view
$this->load->view('default', $data);
} |
We fetch messages from the database using Message_model->get() function. Then the data is passed to the view. Here, we have 2 views called. One for the default view, where we called the page using message/view, and the other is for calling from ajax.
add is a proccess used to insert the message to the database. The codes are:
1
2
3
4
5
6
7
8
9
| function add()
{
// if HTTP POST is sent, add the data to database
if($_POST && $_POST['message'] != NULL) {
$message['message'] = $_POST['message'];
$this->Message_model->add($message);
} else
redirect('message/view');
} |
This function is accessed when we press the submit button from the form. This function will save the message using Message_model->add() function.
Model
The next thing we need to create is the model. I use Message_model for the name. Here we create two functions, add and get. add is a function to insert the data into the database. get is a function to retrieve data from database. I think the codes are pretty self-explainatory, but you could drop me a message if you need some explainations on the codes.
1
2
3
4
| function add($data)
{
$this->db->insert('messages', $data);
} |
1
2
3
4
5
6
7
| function get($limit=5, $offset=0)
{
$this->db->orderby('id', 'DESC');
$this->db->limit($limit, $offset);
return $this->db->get('messages')->result();
} |
View
I use 2 files for view section. default.php and message_list.php. The message_list is used for displaying the messages taken from the database.
1
2
3
4
5
6
7
8
| <div id="form">
<input type="text" id="message" name="message" />
<input type="submit" id="submit" name="submit" value="submit" />
</div>
<div id="content">
<?php $this->load->view('messages_list') ?>
</div> |
1
2
3
4
5
| <ol>
<?php foreach ($messages as $message): ?>
<li><?= $message->message ?></li>
<?php endforeach ?>
</ol> |
Hey, Where’s the JQuery?
Here we go. The last, and maybe the most important part of this tutorial. So, we the our controller, we had the model, and we had the views. I assume you already know how to include a jquery script to your view. The jquery codes are this:
1
2
3
4
5
6
7
8
9
10
11
| $(document).ready(function() {
$('#submit').click(function() {
var msg = $('#message').val();
$.post("<?= site_url('message/add') ?>", {message: msg}, function() {
$('#content').load("<?= site_url('message/view/ajax') ?>");
$('#message').val('');
});
});
}); |
So, when we click the submit button, the javascript will take the value of input textbox then send it to message/add using post method. When the action succeed, the script will call message/view/ajax. Note the ajax keyword. It will call the message_list view instead of the default one. Then the view will replace the content in div#content tag.
Well done. You could see the demo I made from the tutorial.
You could download the whole files used in this tutorial in tutorial.zip (1.98 KB).
Or, if you prefer to get one by one,
controller: message (904 bytes)
model: message model (583 bytes)
view: default (782 bytes)
view: message_list (111 bytes)
I hope this tutorial helps newbie like me. If you have any question, just drop a comment below
May 12th, 2008
While you’re thinking by installing 64 bit linux you’re standing in the edge of new technology era, it sucks knowing our 64 bit system is less supported than the old 32 bit system. We have to install 32 bit flash since Adobe didn’t have the 64 bit one. We have to install 32 bit oracle xe since Oracle also didn’t have 64 bit version.
And now I will try explain how to install oracle xe into the 64 bit system, ubuntu way. Of course we couldn’t follow the guide from oracle, since apt-get will detect our system architecture and we won’t get the 32 bit packages list.
Before we start, make sure you have the 32 bit library installed. It’s in reposity, all you have to do is
sudo apt-get install libc6-i386
The next thing to do is download the files needed. It’s libaio_0.3.104-1_i386.deb and oracle-xe-universal_10.2.0.1-1.1_i386.deb. You could use wget for this
wget -c http://oss.oracle.com/debian/dists/unstable/main/binary-i386/libaio_0.3.104-1_i386.deb http://oss.oracle.com/debian/dists/unstable/non-free/binary-i386/oracle-xe-universal_10.2.0.1-1.1_i386.deb.
After your downloads are finished, we continue to the main issue, forcing the package to be installed. You could try to install with usual dpkg -i first to make sure your system is really 64 bit.
sudo dpkg -i libaio_0.3.104-1_i386.deb
You’ll get error,
dpkg: error processing libaio_0.3.104-1_i386.deb (--install):
package architecture (i386) does not match system (amd64)
Errors were encountered while processing:
libaio_0.3.104-1_i386.deb
Added guide from Venka A
sudo apt-get install bc
To force the installation, do these
dpkg -i --force-architecture libaio_0.3.104-1_i386.deb
dpkg -i --force-architecture oracle-xe-universal_10.2.0.1-1.1_i386.deb
And after the installation is finished, you need to configure it
sudo /etc/init.d/oracle-xe configure
and edit your ~/.bashrc
ORACLE_HOME=/usr/lib/oracle/xe/app/oracle/product/10.2.0/server
PATH=$PATH:$ORACLE_HOME/bin
export ORACLE_HOME
export ORACLE_SID=XE
export PATH
And, voila, the oracle xe is ready. You could go to http://127.0.0.1:8080/apex from your browser.
References: