24 hours a day, 7 days a week, 365 days per year...

October 16, 2019

FOSSCOMM 2019 aftermath

FOSSCOMM 2019 - Lamia

FOSSCOMM (Free and Open Source Software Communities Meeting) is a Greek conference aiming at free-software and open-source enthusiasts, developers, and communities. This year was held at Lamia from October 11 to October 13.

It is a tradition for me to attend to this conference. Usually I have presentations and of course booths to inform the attendees about the projects I represent.

This year the structure of the conference was kind of different. Usually the conference starts on Friday with "beer event". Now it started with registration and a presentation. Personally I made my plan to leave from Thessaloniki by bus. It took me about 4 hours on the road. So when I arrived, I went to my hotel and then waited for Pantelis to go to the University and setup our booths.

FOSSCOMM 2019 - Stathis at openSUSE and GNOME booth

ALERT: Long projects presentation...

Our goal was to put the stickers and leaflets on the right area. This year we had plenty of projects at our booths. We met a lot of friends at Nextcloud conference and we asked them for brochures and stickers. So this year our basic projects were Nextcloud and openSUSE (we had table cloths). We had stickers from GNOME (I had couple of T-Shirts from GUADEC just in case someone wanted to buy one). Since openSUSE sponsorts GNU Health, I was there to inform students about it (it was great opportunity since the department organizing was Bioinformatics department). We had brochures, stickers, chocolate and pencils from ONLYOFFICE, also we had promo material from our friends Turris. We are happy that Free Software Foundation Europe gave us brochures when we were in Berlin, and we were able to inform attendees about the campaigns and the work they are doing for us. We met Collabora guys also and we asked them if they want to promote them, since Collabora and Nextcloud are working together. Finally, our friends from DAVx5, gave us their promo material since the program works with Nextcloud so well.

I warned you!!! Well the first day we met the organizers and the volunteers. I was surprised by the number of volunteers and their willing to help us (even with setting up the booths). The first day ended with going out to eat something. Thank you Olga for introduce us to FRESCO. I used to eat at FRESCO when I was in Barcelona. I guess they're not franchise :-)

Well Saturday started with registration. We put more swag on the booth (we saw that last night they took almost everything). Personally I went to meet other projects. I was glad that my friend Julita applied to present what she's doing at the university (Linux on Supercomputers). I was kind of surprised but happy for her that her talk upgraded to Keynote. Glad I met her at GUADEC. Glad also that she had Fedora booth and gave some different aura to the conference. Check out her blogpost about her FOSSCOMM experience .

Glad I met Boris from Tirana. He did a presentation about Nextcloud as a service with Cloud68. Never met before, although I can say that I know many people from Albania and Open Labs.

FOSSCOMM 2019 - Nextcloud Booth - Stathis, Pantelis, BorisFOSSCOMM 2019 - Nextcloud Booth - Stathis, Pantelis, Boris

My presentation was the last one on Saturday, so I had plenty of time to be at the booth and inform anyone about all the above projects. Also I had the opportunity to attend some talks I wanted to see. Well, my talk was about communities. I described my personal example. I started a little bit about what is contribution to open source projects. I focused on my example, meaning on end users that they like the software, they want to contribute but they don't have a clue about programming languages. Personally I translate and promote (articles, conferences etc). I met a lot of people (Greece and abroad) that I consider friends. Those friends maybe can help find a job (especially you are an IT). The best part though is when we meet AFK and we have fun.
You can see my presentation file here

FOSSCOMM 2019 Stathis Iosifidis Presentation about contribution to communitiesFOSSCOMM 2019 - Contribution to communities, personal example

After my presentation, there was a party (not because I finished it but because it was on schedule ;-) ). We had pizza and wine. Also there was music. We left kind of early (I guess) with some FOSS friends and some volunteers. We had a beer at the center.

On Sunday I left Lamia by car with a friendly couple from Thessaloniki. Well she had a presentation as well (before mine) about "Building digital competency in European small and medium-sized businesses with Free and Open Source Software: Results of the FOSS4SMEs project". I suppose to have another, more interesting talk for the Bioinformatics department (subject: "GNU HEALTH: The fight for our rights to universality and excellence in the Public Health System"), but due to my departure, it was canceled. I asked the organizers the day that the schedule was out to change my talk to Saturday but never got an answer.

Well, I took some videos and I'll upload it on youtube soon. Some volunteers took some pictures and I guess we'll have them soon. When I'll have them all, I'll edit this post.

Finally, I would like to thank Nextcloud for sponsoring my trip to Lamia.

October 04, 2019

Εγκατάσταση του viber με την χρήση flatpak


Είδαμε πως μπορούμε να εγκαταστήσουμε το viber μέσω του snap. Αυτό δεν θεωρείται επίσημος τρόπος για μια διανομή με βάση το GNOME. Πιο επίσημος θεωρείται ο τρόπος της εγκατάστασης του πακέτου flatpak. Πως μπορεί να γίνει αυτό;

1. Εγκατάσταση του flatpak.

sudo zypper install flatpak

2. Εισαγωγή του αποθετηρίου flatpak.

sudo flatpak remote-add --if-not-exists flathub

3. Επανεκκίνηση του συστήματος

Για περισσότερες διανομές, μπορείτε να βρείτε πληροφορίες εδώ.

4. Η εγκατάσταση μπορεί να γίνει απευθείας από την διεύθυνση:

ή αν κάνετε μια αναζήτηση στο software center της διανομής σας.

Εάν θέλετε να ψάξετε περισσότερα προγράμματα, μπορείτε να βρείτε μια λίστα εδώ:

Στην διανομή openSUSE δυστυχώς το πακέτο rpm που κατεβάζουμε από την ιστοσελίδα του viber, δεν δουλεύει. Οπότε αυτός θεωρείται ίσως ο μοναδικός τρόπος για να έχετε viber στον υπολογιστή σας.

August 18, 2014

OPW final report - Greek Translation

Finally, my first contribution to the GNOME Project within the OPW came to an end!!! I can say it was more difficult than expected and required much learning, reading and research for a simple translator like me who has no programming knowledge. 
The main job of the project was to translate and review all GNOME project files in Greek. The Greek translation of GNOME was at a good level, thanks to the work done in previous years by the members of the Greek community. After discussion with the community and my mentor, we found it useful to first do a research on available translation programs and to write a quick guide on How to start using GNOME's translation system.

In order to deliver uniformity we standardized terms and created from scratch a new glossary which took some extra time but is an important tool for all future translations. Also as a new translator Ι wanted a tool to help me search for our glossary terms among the files. The good is closed and "grep"-ing po files weren't so easy and efficient for me.
So along with the glossary, we came up with the idea to set up a pylyglot instance for our language. That was something new and experimental for Greek GNOME community, but it proved to be handy as it helped us to speed up the review and translation process. We could easily check the translated files and the consistency of the whole GNOME environment by just searching specific terms from the glossary at our pylyglot website.

Along the way, and after communication with the mentor and the other members of the community, we decided to modify the initial time schedule, aiming precision and consistency especially regarding the new release files of GNOME 3.14 which I believe has been achieved greatly.  

Many thanks to mentor Efstathios Iosifidis, Tom Tryfonidis and all other team members who helped me on this effort!!!
I can say so far the journey with GNOME has been exciting all the way. 

Thank you GNOME!

August 04, 2014

Greek Translation - OPW Report #7 – week 10-11

This week I had some strange issues with my translation files. Strings I never changed were shown as changed from me in the diff with the repository files. It seems to be a conflict with older files and I still try to figure out whether the problem my PO editor is or the localization application (l10n). If anyone had similar issues or any idea of the cause, I would appreciate any kind of help.

I'm still working on the 3.14 release files and reviewed – translated following ones:

UI Translations:
seahorse, vino, gnome-disk-utility, gdm, gucharmap, gnome-desktop           

Only translation of new strings (files have already been reviewed):
gnome-photos, file-roller, bijiben, iagno, gnome-shell, gnome-control-center, gitg, Evince Document Viewer, gedit, gnome-boxes, gnome-klotski, gnome-mahjongg, gnome-sudoku, dconf, tracker, gtksourceview, gnome-maps, gnome-weather

GNOME User Documentation, gtk-doc

January 23, 2012

Bypass Firewalls with Android SSH Tunneling

January 05, 2012

How to clean PHP code after injection

Did someone hack your PHP files ? Is that possible ? Oooh yes. It happens to everybody and the difference between "everybody" is how often it happens. And code injection is one type of attack, I won't refer to cases that someone changed the homepage and you can just restore the last backup.

So, what can you do if you find out that someone injected code into your PHP files ?

July 23, 2011

Systray και popup menu με το Glade

Σε αυτό το άρθρο θα παρουσιάσουμε πως μπορεί η εφαρμογή μας να έχει ένα εικονίδιο στον δίσκο συστήματος (systray) και πως κάνοντάς του κλικ μας εμφανίζει το κεντρικό παράθυρο της εφαρμογής ή ένα popup μενού για έλεγχό της.

Θα φτιάξουμε ένα μικρό slider που θα ελέγχει την ένταση του ήχου, όπως αυτό που υπάρχει ήδη στα περισσότερα συστήματα linux. Έχει καθαρά εκπαιδευτικούς σκοπούς δείχνοντας την αλληλοεπίδραση μεταξύ των σημάτων του systray και του προγράμματος. Για τον έλεγχο του ήχου θα χρησιμοποιήσουμε είτε την βιβλιοθήκη alsaaudio της python είτε την εντολή amixer του συστήματος της ALSA.

Δημιουργούμε το παράθυρο μας στο Glade και του δίνουμε όνομα volumewindow. Στον Τύπο παραθύρου επιλέγουμε Αναδυόμενο (popup). Αυτού του είδους τα παράθυρα δεν έχουν πλαίσιο και διακοσμήσεις και δεν τα ελέγχει ο window manager του συστήματος. Στις αιτήσεις πλάτους και ύψους δίνουμε αντίστοιχα 60 και 170 pixels, ενώ στο Πλάτος πλαισίου δίνουμε τιμή 2. Αυτό είναι το περιθώριο που θα έχουν όλα τα αντικείμενα του παραθύρου από τις άκρες του.

Στην συνέχεια προσθέτουμε ένα frame και αφαιρούμε τα alignment και label που δημιουργεί. Επιλέγουμε την σκίαση της αρεσκείας μας και προσθέτουμε μέσα του ένα πλαίσιο fixed. Αυτό το πλαίσιο μας επιτρέπει να τοποθετήσουμε αντικείμενα σε συγκεκριμένες θέσεις μέσα του. Βλέπουμε ότι έχουμε και αυτήν την δυνατότητα εκτός από την τοποθέτηση σε γραμμές και στήλες. Στην συγκεκριμένη περίπτωση είναι χρήσιμο γιατί το παράθυρο δεν μπορεί να αλλάξει μέγεθος και έτσι με λίγο πειραματισμό μπορούμε να τοποθετήσουμε τα διάφορα widget όπου ακριβώς θέλουμε και να είμαστε σίγουροι ότι πάντα θα φαίνονται έτσι.

Προσθέτουμε μία Κατακόρυφη κλιμακα (slider) και την ονομάζουμε masterslider. Θέτουμε τα Ψηφία στο μηδέν, την Θέση τιμής κάτω και την ορίζουμε σαν Αντεστραμμένη. Προσθέτοντας μια νέα Ρύθμιση το glade την ονομάζει αυτόματα adjustment1 και της δίνει ορισμένες αρχικές τιμές. Αλλάζουμε την Μέγιστη τιμή σε 100, τον Ρυθμό αύξησης βήματος σε 1, την Αύξηση σελίδας σε 10 και το Μέγεθος σελίδας σε 0.

Επιστρέφοντας στο masterslider και στο tab packing βλέπουμε ότι τα συνηθισμένα Γέμισμα και Ανάπτυξη έχουν αντικατασταθεί από τα Θέση Χ και Θέση Υ , λόγω του ότι βρίσκετε μέσα σε fixed πλαίσιο. Σε αυτά βάζουμε αντίστοιχα τις τιμές 10 και 6. Στα Σήματά του και συγκεκριμένα στο value-changed δίνουμε σαν handler την μέθοδο masterslider_change. Αυτή θα αλλάζει την ένταση του ήχου ανάλογα με την θέση του slider.

Στην συνέχεια προσθέτουμε ένα button με το όνομα button, και στην ετικέτα του βάζουμε Mixer. Στις θέσεις Χ και Υ βάζουμε 1 και 132 αντίστοιχα, ενώ στο σήμα clicked δίνουμε σαν handler button_clicked. Αυτή η μέθοδος θα εμφανίζει το gnome-alsamixer, αν υπάρχει στο σύστημα.

Με το μικρό μας παράθυρο έτοιμο ας προσθέσουμε τα υπόλοιπα αντικείμενα που χρειαζόμαστε για το πρόγραμμα μας. Επιλέγουμε ένα Αναδυόμενο μενού (popup) και του δίνουμε το όνομα menu. Με το menu επιλεγμένο πατάμε edit στην μπάρα εργαλείων και προσθέτουμε δύο Στοιχεία εικόνας. Για το πρώτο επιλέγουμε το έτοιμο κουμπί stock Περί και για το άλλο το Έξοδος. Στα activate σήματα τους βάζουμε σαν handler αντίστοιχα τις μεθόδους about dialog και close_window.

Το βασικότερο μας αντικείμενο είναι ένα Εικονίδιο γραμμής κατάστασης το οποίο θα το βρούμε στα Διάφορα. Προσθέτουμε ένα και το ονομάζουμε staticon. Στο Pixbuf γράφουμε το όνομα του αρχείου του εικονιδίου που θα χρησιμοποιήσουμε. Υπάρχουν πολλά εικονίδια που μπορείτε να χρησιμοποιήσετε στον κατάλογο /usr/share/icons/gnome. Αντιγράψτε ένα της αρεσκείας σας στον ίδιο κατάλογο με τα αρχεία glade και python. Στον Τίτλο δίνουμε SysAudio. Αυτό θα εμφανίζεται όταν περνάει ο δείκτης του ποντικιού από πάνω του. Στα Σήματα του δίνουμε στο activate την μέθοδο window_show και στο popup-menu την menu_popup. Η πρώτη μέθοδος εκτελείται όταν ο χρήστης κάνει αριστερό κλικ πάνω στο εικονίδιο και θα εμφανίσει το παράθυρο μας με τον slider, ενώ η δεύτερη όταν κάνει ένα από τα υπόλοιπα και συγκεκριμένα δεξί κλικ, εμφανίζοντας το μενού της εφαρμογής.

Τα βασικά αντικείμενα της εφαρμογής είναι τα εξής:

Σε αυτό το σημείο το αρχείο glade είναι έτοιμο, έχουμε προσδιορίσει ότι θα χρειαστούμε και το σώζουμε σαν Το πρόγραμμα μας σε python είναι απλό και περιέχει στοιχεία που έχουμε δει ήδη.

#!/usr/bin/env python
# -*- coding: utf-8 -*-

import os
    import alsaaudio
    import subprocess
    import commands
import pygtk
import gtk

class VolumeControl():

    def __init__(self):
        self.window = builder.get_object("volumewindow")
        self.window_position = (0, 0)
        self.staticon = builder.get_object("staticon") = builder.get_object("menu")
        self.masterslider = builder.get_object("masterslider")

    def close_window(self, widget, data=None):

    def button_clicked(self, widget):

    def window_show(self, widget, data=None):
        if self.window.get_property('visible'):
            self.window.move(self.window_position[0], self.window_position[1])
    def menu_popup(self, widget, button, time, data = None):
        if button == 3:
  , None, None, 3, time)

    def masterslider_change(self, widget):
        volume = int(widget.get_value())
        if HAVEALSA:
            mix = alsaaudio.Mixer()
            proc = subprocess.Popen('/usr/bin/amixer sset Master ' \
                    + str(volume) + '%', shell=True, stdout=subprocess.PIPE)

    def set_window_position(self):
        staticon_geometry = self.staticon.get_geometry()[1]
        if staticon_geometry.y <= 200:
            y_coords = staticon_geometry.y
            y_coords = staticon_geometry.y-180
        self.window_position = (staticon_geometry.x+20, y_coords+10)

    def get_master_volume(self):
        if HAVEALSA:
            mix = alsaaudio.Mixer()
            return mix.getvolume()[0]
            output = commands.getoutput('/usr/bin/amixer sget Master | grep "%"')
            master = output.split('\n')[0]
            start = master.find('[') + 1
            end = master.find('%]', start)
            return float(master[start:end])

    def aboutdialog(self, widget, data=None):
        about = gtk.AboutDialog()
        about.set_program_name('Volume Control')
        about.set_comments(u'Πρόγραμμα ελέγχου της στάθμης του ήχου.')

    def main(self):

if __name__ == "__main__":

Στην αρχή προσπαθούμε να φορτώσουμε την βιβλιοθήκη alsaaudio και αν αυτό αποτύχει φορτώνουμε τις subprocess και command για να μπορέσουμε να εκτελέσουμε εντολή του συστήματος και να πάρουμε το αποτέλεσμα της. Ορίζουμε και μια μεταβλητή για να ξέρουμε αν έχουμε φορτώσει την alsaaudio ή όχι. Οι βασικές μέθοδοι είναι γνωστές από τα προηγούμενα άρθρα. Στην __init__ φορτώνουμε το glade αρχείο και ορίζουμε τις μεταβλητές που θα χρησιμοποιήσουμε. Η aboutdialog δημιουργεί και δείχνει το παράθυρο “Περί” όταν πατήσει ο χρήστης την αντίστοιχη επιλογή στο μενού και η close_window τερματίζει το πρόγραμμα.

Η get_master_volume επιστρέφει την τιμή που έχει η ένταση του ήχου κατά τη στιγμή της κλήσης της. Χρησιμοποιεί είτε την getvolume της alsaaudio είτε το αποτέλεσμα της εντολής “amixer sget Master”. Η set_window_position θέτει την θέση του παραθύρου λίγο πιο κάτω και λίγο πιο δεξιά από το εικονίδιο.

Η window_show εκτελείται όταν ο χρήστης κάνει αριστερό κλικ στο εικονίδιο και το κρύβει αν αυτό είναι ήδη ορατό ή το εμφανίζει αφού πρώτα υπολογίσει την τιμή του ήχου και την θέση του παραθύρου. H present που καλείται στο τέλος έχει σαν σκοπό να εμφανίζει το παράθυρο αν αυτό καλύπτεται από κάποιο άλλο.

Η master_slider_change εκτελείται όταν ο χρήστης αλλάξει την θέση του slider και αναλόγως αυτής θέτει την τιμή της έντασης είτε με την setvolume είτε με την “amixer sset Master”.

Η menu_popup εμφανίζει το μενού της εφαρμογής. Τα popup menu χρειάζονται για να εμφανιστούν τον αριθμό του κουμπιού του ποντικιού που πατήθηκε και την χρονική στιγμή που έγινε το γεγονός. Αυτά και τα δύο μας τα δίνει το σήμα popup-menu του εικονιδίου, εμείς μένει μόνο να ελέγξουμε αν το κουμπί που πατήθηκε είναι το δεξί.

Η button_clicked εμφανίζει το gnome-alsamixer, αν είναι εγκατεστημένο, αλλιώς θα εμφανίσει μήνυμα λάθους στην γραμμή εντολών. Εδώ μπορείτε, με τις πληροφορίες από τα προηγούμενα άρθρα, να προσθέσετε ένα ErrorDialog για να ενημερώνεται ο χρήστης.

Είναι μια απλή εφαρμογή αλλά δείχνει τα στοιχεία που χρειάζονται για την δημιουργία ενός systray προγράμματος. Με τον ίδιο τρόπο διάφορα προγράμματα, όπως η Opera και το Transmission, βάζουν ένα εικονίδιο στο systray και το πρόγραμμα δεν τερματίζει αν ο χρήστης πατήσει το Χ στο παράθυρο του αλλά κρύβεται απλώς και εμφανίζεται πάλι αν ο χρήστης κάνει αριστερό κλικ στο εικονίδιο, ενώ με δεξί εμφανίζει είτε μενού είτε πληροφορίες του προγράμματος.

Τα αρχεία του άρθρου υπάρχουν σε .tar.gz εδώ

June 26, 2011

Σύνθετα αντικείμενα στο Glade (γ' μέρος)

Σε αυτό το άρθρο θα παρουσιάσουμε το πρόγραμμα, γραμμένο σε python, που μετατρέπει τις κωδικοποιήσεις των αρχείων. Το πρόγραμμα καθώς και τα συνοδευτικά του αρχεία βρίσκονται εδώ.

#!/usr/bin/env python
# -*- coding: utf-8 -*-

import gtk
import os
import codecs

CODEPAGES = ['utf_16','utf_8','cp1253','iso8859_7']
EOL = ['Windows','Unix','Mac']
DICT_EOL = {'Windows':'\r\n','Unix':'\n','Mac':'\r'}

class FileToConvert(object):

    def __init__(self,fn = None, cp = None, eol=None):
        self.fn = fn
        self.cp = cp
        self.eol = eol
        self.to_cp = ''
        self.to_eol = ''

    def checkfile(self,codefrom=None):
        if codefrom:
        for enc in encodings:
                if '\r\n' in line:
                    self.eol = EOL[0]
                elif '\n' in line:
                    self.eol = EOL[1]
                elif '\r' in line:
                    self.eol = EOL[2]
        return ret    

class ConvertFiles(object):

    def close_window(self, widget, data=None):

    def delete_chooser(self, widget, data=None):
        return True

    def aboutmenu_clicked(self, widget, data=None):

    def helpmenu_clicked(self, widget, data=None):
        import webbrowser"help.html")

    def openmenu_clicked(self, widget, data=None):

    def filterbox_changed(self, widget, data=None):
        if widget.get_active() == 0:
        if widget.get_active() == 1:
        if widget.get_active() == 2:

    def filelistview_key(self, widget, data=None):
        treeviewmodel, treeviewindex = widget.get_selection().get_selected()
        if (gtk.gdk.keyval_name(data.keyval) == 'Delete') and treeviewindex:

    def filelist_row_deleted(self,widget,data=None):
        del self.files[data[0]]
        self.statusbar.push(0,"Αφαίρεση αρχείου")

    def filechooser_cancel(self, widget, data=None):

    def filechooser_ok(self, widget, data=None):
        if self.files:
            for fi in self.files:
        for fi in self.filechooser.get_filenames():
            if fi not in filenames:
                newfile = FileToConvert(fi)
                if newfile.checkfile():
                    errortxt+=u"Πρόβλημα στην ανάγνωση του αρχείου: %s.\n" % cf.fn
        if i>0:
            self.statusbar.push(0,u"Επιτυχής αναγνωση %d αρχείων" % i)

    def errordialog(self, errortxt):
        dialog=gtk.MessageDialog(parent=None,flags=gtk.DIALOG_MODAL & gtk.DIALOG_DESTROY_WITH_PARENT, type=gtk.MESSAGE_ERROR, buttons=gtk.BUTTONS_OK)
        if response == gtk.RESPONSE_DELETE_EVENT or response == gtk.RESPONSE_OK:

    def savemenu_clicked(self, widget, data=None):
        if not self.files:
            self.errordialog(u"Δεν έχετε επιλέξει αρχεία.\n")
        for fi in self.files:
            if self.codefrombox.get_active()>0:
                if not fi.checkfile(CODEPAGES[self.codefrombox.get_active()-1]):
                    errortxt+=u"Πρόβλημα στην ανάγνωση του αρχείου: %s.\n" % fi.fn
        if errortxt:
            self.statusbar.push(0,u"Δεν ήταν σωστή η κωδικοποίηση που ορίσατε.")
        for i in range(len(self.files)):
        for fi in self.files:
                for line in t1:
                self.errordialog(u"Πρόβλημα στην μετατροπή του %s.\n" % fi.fn)
                if fi.checkfile():
                    fi.to_cp = ''
                    fi.to_eol = ''
                    self.errordialog(u"Πρόβλημα στην τελική ανάγνωση του %s.\n" % fi.fn)
        if success:
            self.statusbar.push(0,u"Επιτυχής μετατροπή")
            self.statusbar.push(0,u"Προβλήματα στην μετατροπή")
    def __init__(self):
        builder = gtk.Builder()
        self.window = builder.get_object("convertwindow")
        self.codefrombox = builder.get_object("codefrombox")
        self.codetobox = builder.get_object("codetobox")
        self.eolbox = builder.get_object("eolbox")
        self.codefromlist = builder.get_object("codefromlist")
        self.codetolist = builder.get_object("codetolist")
        self.eollist = builder.get_object("eollist")
        self.filelist = builder.get_object("filelist")
        for item in CODEPAGES:
        for item in EOL:
        self.filechooser = builder.get_object("filechooser")
        self.aboutdialog = builder.get_object("aboutdialog")
        self.txtfilter = builder.get_object("txtfilter")
        self.srtfilter = builder.get_object("srtfilter")
        self.allfilter = builder.get_object("allfilter")
        self.filterbox = builder.get_object("filterbox")
    def main(self):

if __name__== "__main__":
Ξεκινάμε στην αρχή με τα απαραίτητα import. Το νέο εδώ είναι η βιβλιοθήκη codecs, η οποία θα μας χρησιμεύσει στις μετατροπές. Στην συνέχεια υπάρχουν τρεις σταθερές. Η πρώτη περιέχει τα λεκτικά των κωδικοποιήσεων έτσι όπως τα χρειάζεται η codecs και με αυτά γεμίζουμε και τα δύο μας combobox. H EOL σταθερά είναι αυτή που περιέχει τα λεκτικά για τα διάφορα τελειώματα γραμμής που υπάρχουν. Στην επόμενη σταθερά γίνεται συσχέτιση μεταξύ αυτών των λεκτικών και των πραγματικών τιμών που έχει το κάθε τέλος γραμμής.

Θα χρειαστούμε να ορίσουμε ένα αντικείμενο για κάθε αρχείο που θα διαλέξει ο χρήστης κι αυτό θα φτιαχτεί από την κλάση FileToConvert. Το αντικείμενο θα περιέχει τις εξής πληροφορίες: το όνομα του αρχείου, την κωδικοποίηση και το τέλος γραμμής που έχει πριν την μετατροπή καθώς και σε τι θέλουμε να το μετατρέψουμε. Η κλάση ακόμα περιλαμβάνει την μέθοδο checkfile η οποία προσπαθεί να μαντέψει ποια από τις τέσσερις κωδικοποιήσεις και ποιο από τα τρία EOL έχει το αρχείο. Αν είναι επιτυχής επιστρέφει True, αλλιώς False.

Στην κύρια κλάση έχουμε προσθέσει στην __init__ μέθοδο δύο μεταβλητές, την self.filelist η οποία είναι το μοντέλο του TreeView και την self.files στην οποία θα κρατάμε τα αντικείμενα FilesToConvert.

H μέθοδος filelistview_key εκτελείται όταν ο χρήστης πατήσει ένα πλήκτο. Η get_selected() επιστρέφει δύο τιμές το μοντέλο στο οποίο ανήκει το TreeView και τον αύξων αριθμό της επιλογής. Έτσι λοιπόν ελέγχουμε αν ο χρήστης έχει πατήσει Delete και αν έχει επιλέξει γραμμή. Τότε μόνο διαγράφουμε την αντίστοιχη επιλογή από το μοντέλο. Όταν διαγραφεί ένα στοιχείο από το μοντέλο εκτελείται η filelist_row_deleted στην οποία διαγράφουμε το αντίστοιχο αντικείμενο από την self.files.

Όταν ο χρήστης επιλέξει αρχεία φτιάχνουμε έναν προσωρινό πίνακα με τα ονόματα των αρχείων που υπάρχουν ήδη έτσι ώστε να αποφύγουμε τις διπλές εισαγωγές. Στην συνέχεια για κάθε αρχείο φτιάχνουμε το αντίστοιχο αντικείμενό του και καλούμε την chekfile για να προσδιορίσει τον τύπο του αρχείου και του τέλους της γραμμής του. Για κάθε επιτυχή αναγνώριση προσθέτουμε τα αντίστοιχα πεδία στην self.filelist για να εμφανιστούν στο TreeView.

Εδώ θα θέλαμε να αναφέρουμε ορισμένα στοιχεία για την Αυτή όταν ανοίγει ένα αρχείο για διάβασμα το ανοίγει πάντα σε binary mode. Αυτό έχει σαν αποτέλεσμα να μην χτυπάει λάθος όταν αρχείο δεν είναι text. Ακόμα επειδή οι λατινικοί χαρακτήρες έχουν την ίδια κωδικοποίηση τόσο σε utf-8 όσο και σε windows-1253 ή ISO8859-7 μπορεί να μην δώσει σωστό αποτέλεσμα σε αρχεία με μόνο τέτοιους χαρακτήρες. Ένα άλλο σημείο προσοχής είναι ότι η μόνη διαφορά, στους ελληνικούς εμφανίσιμους χαρακτήρες, μεταξύ των windows-1253 και ISO8859-7 είναι το άλφα κεφαλαίο τονούμενο (Ά), οπότε πάλι μπορεί να έχουμε λάθος προσδιορισμό. Γι´ αυτό και βάλαμε την επιλογή “Κωδικοποίηση από” για να μπορεί να επιλέξει ο χρήστης αν γνωρίζει την κωδικοποίηση του αρχείου προς μετατροπή.

Η μετατροπή γίνεται στην savemenu_clicked, ανοίγοντας με την σειρά τα αρχεία που υπάρχουν στην self.files με την κωδικοποίηση που έχει ορίσει ο χρήστης και σώζοντας τα σε ένα προσωρινό με την νέα. Αν όλα πάνε καλά τα ξαναδιαβάζει για να ενημερώσει το TreeView και για να δει ο χρήστης το αποτέλεσμα.

Καθ' όλη την διαδικασία της μετατροπής το πρόγραμμα ενημερώνει τον χρήστη με δύο τρόπους. Ο ένας είναι ο διάλογος μηνυμάτων που έχουμε δει και σε προηγούμενο άρθρο και ο άλλος είναι μέσω της statusbar. Η statusbar λειτουργεί σαν στοίβα LIFO. Βάζουμε στην στοίβα αυτό που θέλουμε να εμφανίσει με push και το αφαιρούμε με pop. Κάθε μήνυμα μπορεί να έχει και ένα αναγνωριστικό κωδικό, προσδιορίζοντας έτσι από πιο μέρος του προγράμματος προήλθε. Εδώ δεν χρησιμοποιούμε αυτήν την δυνατότητα γι' αυτό όλα τα μηνύματα έχουν σαν προσδιοριστικό το μηδέν.

Είδαμε σ' αυτό το άρθρο ορισμένα από τα πιο βασικά σύνθετα αντικείμενα του Gnome και του GTK και πως τα αναπτύσσουμε αυτά μέσα από το Glade. Βλέπουμε ότι ενώ αυτά είναι αρκετά πιο πολύπλοκα από ένα απλό label ή ένα text input, ωστόσο όλη η διαδικασία δημιουργίας και ελέγχου τους ολοκληρώνεται μέσα από το Glade προσθέτοντας ελάχιστο προγραμματιστικό βάρος.

May 26, 2011

Μαθαίνοντας τα πρόσθετα του Gnome shell

Gnome logo

Το gnome shell είναι το νέο interface του GNOME 3.Ήρθε να αντικαταστήσει τη παλιά επιφάνεια εργασίας του Gnome επιφέροντας αρκετές αλλαγές στη λειτουργικότητα αλλά και στην εμφάνιση του Gnome.

Μαζί με το gnome shell ήρθαν και νέα extensions (οι devs λένε πως δεν ήρθαν να αντικαταστήσουν τα applets!) κάνοντας τη ζωή μας πιο εύκολη !! Παρακάτω θα παρουσιάσω μερικά από τα extensions που βρήκα και με τον ένα ή αλλο τρόπο μπορούν να χρησιμεύσουν στον καθένα μας.


Πως εγκαθιστώ τα extensions του Gnome Shell ;
Πως θα ενεργοποιήσω τα πρόσθετα ;

Extensions που υπάρχουν για το Gnome Shell


Κάντε το Gnome shell να μοιάζει με το Gnome 2 (extensions από Ron Yorston)

Move the clock
Favorites in panel
Disable dynamic workspaces
Applications menu in panel

Χρήση του GnomeTweakTool
Λοιπά – toDO

Πως εγκαθιστώ τα extensions του Gnome Shell ;

Πριν προχωρήσουμε,να πω ότι οι τοποθεσίες που βρίσκονται τα extensions είναι:

  • /usr/share/gnome-shell/extensions/ (διαθέσιμα για όλους τους χρήστες του συστήματος)
  • $HOME/.local/share/gnome-shell/extensions/ (διαθέσιμα μόνο για έναν χρήστη)

Υπάρχουν 2 τρόποι για να κάνετε εγκατάσταση τα extension του gnome shell.

Ο πρώτος είναι να υπάρχουν στα αποθετήρια της διανομής σας και μεσω του διαχειριστή πακέτων σας να τα κάνετε από εκεί εγκατάσταση.

Ο δεύτερος τρόπος είναι να κατεβάσετε το extension που θέλετε και να βάλετε σε μια από τις δύο τοποθεσίες που αναφέραμε πριν.

Πίσω στα περιεχόμενα..

Πως θα ενεργοποιήσω τα πρόσθετα ;

Απλά κάνετε μια επανεκκίνηση το gnome shell.Πατήστε alt+F2 πληκτρολογήστε το r,enter και είμαστε έτοιμοι!

Πίσω στα περιεχόμενα..


dock-1Ένα από τα πρόσθετα του gnome shell είναι το dock.Το dock εμφανίζει τις αγαπημένες εφαρμογές που έχουμε ορίσει στην επιφάνεια εργασίας,για να έχουμε γρήγορη πρόσβαση σε αυτές.

Λήψη του extension από το git του Gnome.


Fedora: yum install gnome-shell-extensions-dock
openSUSE: zypper install
Arch Linux: pacman -S gnome-shell-extension-dock

Αν για κάποιο λόγο δεν σας βολεύει το dock μπορείτε να χρησιμοποιήσετε το cairo-dock,awn κ.λπ που έχουν περισσότερες επιλογές.

dock-2 dock-3

Πίσω στα περιεχόμενα..


Το extension αυτό επαναφέρει τη συμπεριφορά της συντόμευσης Alt+Tab στη παλιά λειτουργία του.Συγκεκριμένα γίνεται εναλλαγή των εφαρμογών σε σχέση με τα ανοιχτά παράθυρα (όπως παλιά..) και όχι σε σχέση με τις ανοιγμένες εφαρμογές.


Λήψη του extension από το git του Gnome.


Fedora: yum install gnome-shell-extensions-alternate-tab
openSUSE: zypper install
Arch Linux: pacman -S gnome-shell-extension-alternate-tab
Πίσω στα περιεχόμενα..


alt-menu-extensionΣτο τωρινό status menu η επιλογή suspend είναι η μόνη εμφανή επιλογή.Όταν θέλουμε να κλείσουμε τον υπολογιστή μας πρέπει να πατήσουμε το Alt και να κάνουμε κλικ στο Shutdown που θα εμφανιστεί.

Το extension αυτό εμφανίζει πάντα την επιλογή του Shutdown και του Hibernate όπως επίσης και αυτή του Suspend που υπήρχε ήδη.

Λήψη του extension από το git του Gnome.


Fedora: yum install gnome-shell-extensions-alternative-status-menu
openSUSE: zypper install
Arch Linux: pacman -S gnome-shell-extension-alternative-status-menu
Πίσω στα περιεχόμενα..


drive-menu-extensionΤο συγκεκριμένο πρόσθετο κάθε φορά που συνδέουμε μια εξωτερική αποθηκευτική συσκευή ενεργοποιείται.Είτε είναι usb είτε εξωτερικός δίσκος θα εμφανιστεί δίνοντας μας δύο επιλογές.Του umount και του άνοιγμα του περιηγητή.

Λήψη του extension από το git του Gnome.


Fedora: yum install
openSUSE: zypper install gnome-shell-extensions-drive-menu
Arch Linux: pacman -S gnome-shell-extension-drive-menu
Πίσω στα περιεχόμενα..


places-menu-extensionΤο extension προσθέτει ένα μενού με τις τοποθεσίες του συστήματος.Έτσι έχουμε εύκολη και γρήγορη πρόσβαση όπου θελήσουμε!!

Λήψη του extension από το git του Gnome.


Fedora: yum install gnome-shell-extensions-places-menu
openSUSE: zypper install
Arch Linux: pacman -S gnome-shell-extension-places-menu


Πίσω στα περιεχόμενα..


Το user theme extension μας δίνει τη δυνατότητα να προσθέσουμε θέματα στο gnome shell.
Αφού το κάνουμε εγκατάσταση,μετά απλώς τοποθετούμε το φάκελο του θέματος στη τοποθεσία: $HOME/.themes/

Τέλος για να γίνει η εφαρμογή του θέματος,πατάμε alt+F2 πληκτρολογούμε r και enter.

Επίσης ρίξτε μια ματιά στο GNOME tweak tool.Μπορείτε εύκολα μεσα από το GUI του,να αλλάξετε το θέμα του gnome shell παραβλέποντας τη παραπάνω διαδικασία.

Λήψη του extension από το git του Gnome.


Fedora: yum install gnome-shell-extensions-user-theme
openSUSE: zypper install
Arch Linux: pacman -S gnome-shell-extension-user-theme
Πίσω στα περιεχόμενα..

User-theme selector


Το user theme selector λειτουργεί συνήθως με το extension που αναφέραμε πριν.Δημιουργεί ένα νέο tab (themes) δίπλα από τις Εφαρμογές με όσα θέματα έχουμε τοποθετήσει για ευκολότερη επιλογή.

Ιστότοπος project: @


Η εγκατάσταση θα γίνει χειροκίνητα,όπως αναφέραμε στο Πως εγκαθιστώ τα extensions του Gnome Shell ;
Πίσω στα περιεχόμενα..

Κάντε το Gnome shell να μοιάζει με το Gnome 2

Παρακάτω θα παρουσιάσουμε 4 extensions που σαν βασικό σκοπό έχουν τη μετατροπή του gnome shell στο παλιό γνώρισμο σε όλους Gnome 2.Οπότε έχουμε και λεμε:

Ιστότοπος του project: @ Ron Yorston

Move the clock

Το extension αυτό μετακινεί το ρολόι από το κέντρο που βρίσκεται στη δεξια μεριά της μπάρας του gnome shell.


Favortites in panel

Όπως φαίνεται και από την ονομασία του extension,οι αγαπημένες μας εφαρμογές εμφανίζονται στη μπάρα δίπλα από το Activities (σ.σ Applications αν θα εφαρμόσουμε το παρακάτω extension.)


Disable dynamic workspaces

Αυτό το extension απενεργοποιεί τη δημιουργία νέου δυναμικού workspace όταν μια εφαρμογή εκκινηθεί σε αυτό.Μπορούμε να ορίσουμε εμείς πόσα workspaces θέλουμε να έχουμε,όπως στο Gnome 2 όπου είχαμε εξ’ αρχής 4 στατικά workspaces.
Για να ορίσουμε 4 workspaces εκτελούμε την ακόλουθη εντολή:

gconftool-2 -t int -s /apps/metacity/general/num_workspaces 4

Applications menu in panel


Το συγκεκριμένο extension αντικαθιστά με ένα drop down μενού το κουμπί Activities,με τις εφαρμογές που έχουμε στον υπολογιστή μας.


Μέχρι στιγμής δεν γνωρίζω αν υπάρχουν πακέτα για διανομές.Γι αυτό το λόγο η εγκατάσταση θα γίνει χειροκίνητα στους φακέλους,όπως αναφέραμε στο Πως εγκαθιστώ τα extensions του Gnome Shell ;
Πίσω στα περιεχόμενα..

Χρήση του GnomeTweakTool

Πρόκειται για μια εφαρμογή που μας επιτρέπει να επεξεργαστούμε το gnome shell.ΜΑς φίνει τη δυνατότητα να αλλάξουμε το μέγεθος των γραμματοσειρών,
επαναφορά των κουμπιών ελαχιστοποίησης και μεγιστοποίησης,επαναφορά της παλιάς επιφάνειας εργασίας του Gnome,επιλογή για την αλλαγή του θέματος του gnome shell και ένα σωρό άλλες ρυθμίσεις!!

Ιστότοπος του project: Gnome Tweak Tool



Το Gnome Tweak Tool υπάρχει πλέον στις περισσότερες διανομές linux.Ενδεικτικά μερικές από αυτές έιναι:

Fedora: yum install gnome-tweak-tool
openSUSE: zypper install gnome-tweak-tool
Arch Linux: pacman -S gnome-tweak-tool
Πίσω στα περιεχόμενα..

Λοιπά – toDO

Τα πακέτα για το fedora δεν έχουν ελεγχθεί,οι ονομασίες μπήκαν σε σχέση με αυτά που βρήκα στο

Προσθήκη νέων extension..

Πίσω στα περιεχόμενα..

February 11, 2010 3.2 is out!!

Οι επίσημες ελληνικές εκδόσεις του 3.2 ειναι διαθέσιμες

1) Ελληνικό OOo 3.2 για Linux x86 (rpm)
2) Ελληνικό OOo 3.2 για Linux x86 (rpm με jre)
3) Ελληνικό OOo 3.2 για Linux x86 (deb)
4)Ελληνικό OOo 3.2 για Windows (με jre)
5)Ελληνικό OOo 3.2 για Windows (χωρίς jre)
6) Ελληνικό OOo 3.2 για MacOSX
7) Ελληνικό OOo 3.2 για Solaris Sparc
8) Ελληνικό OOo 3.1.1 για Solaris x86
9) Ελληνικό OOo 3.2 για Linux 64-bit RPM (με jre)
10) Ελληνικό OOo 3.2 για Linux 64-bit deb

(απεγκαταστήστε πρωτα την παλιά σας έκδοση)
1. Αποσυμπιέστε το OOo_xxxLinuxX86_install_el_rpm.tar.gz
2. cd στο κατάλογο που αποσυμπιέσατε τα αρχεία (RMPS)
3. sudo rpm -Uvih *rpm.
4) cd στο κατάλογο Desktop-integration και εγκαταστήστε το ανάλογο rpm για την διανομή σας

rpm with Jre
1. Αποσυμπιέστε το OOo_xxxLinuxX86_install_el_rpm.tar.gz
2. cd στο κατάλογο που αποσυμπιέσατε τα αρχεία (RMPS)
3. Τρέξτε ως root το JavaSetup.jar


1. Απεγκαταστήστε την έκδοση που έχετε στο σύστημα σας
2. Αποσυμπιέστε το OOo_xxxLinuxX86_install_el_deb.tar.gz
3. cd στο κατάλογο που αποσυμπιέσατε τα αρχεία (DEBS)
4. sudo dpkg --install --force-overwrite *.deb
5. cd στο κατάλογο Desktop-integration και εγκαταστήστε το ανάλογο deb για την διανομή σας

November 09, 2009

Ο Mozilla Firefox έγινε 5 χρονών!!

Ο Mozilla Firefox έγινε 5 χρονών!


Σήμερα συμπληρώνονται πέντε χρόνια από την ημερομηνία κυκλοφορίας της πρώτης επίσημης έκδοσης του Mozilla Firefox (και μην ξε χάσετε να δείτε το εορταστικό βιντεάκι στο ).

Πέντε χρόνια που άλλαξαν τον τρόπο που βλέπαμε και αλληλεπιδρούσαμε με τον παγκόσμιο ιστό και πρόσφεραν την ελευθερία σε χρήστες και δημιουργούς.

Για πρώτη φορά ένα προϊόν ελεύθερου λογισμικού είχε τόσο μεγάλη απήχηση από το ευρύ κοινό, τους ειδικούς και τους δημιουργούς.

Γιατί πολύ απλά ήταν και είναι ένα προϊόν που δημιουργήθηκε με τον χρήστη στο επίκεντρο του ενδιαφέροντος και όχι το εμπορικό κέρδος.

Όταν η καθημερινή χρήση του διαδικτύου ήταν ένας επικίνδυνος ακροβατισμός ανάμεσα σε αναδυόμενα παράθυρα, ιούς, κενά ασφαλείας που παρέμεναν ανοιχτά για μήνες και συχνότατες καταρρεύσεις, ο Mozilla Firefox ήταν αυτός που έκανε γνωστά στο ευρύ κοινό έννοιες όπως τη φραγή αναδυόμενων, την περιήγηση σε καρτέλες, το σεβασμό στα πρότυπα ανάπτυξης ιστοσελίδων, την άρνηση εκτέλεσης επικίνδυνου κώδικα, την ενσωμάτωση της αναζήτησης στην εργαλειοθήκη και άλλα.

Πράγματα που σήμερα θεωρούμε δεδομένα και απαραίτητα για ένα περιηγητή, εκείνη την εποχή θεωρούνταν και ήταν επαναστατικά.

Όπως επαναστατικό ήταν και είναι το μοντέλο ανάπτυξης του Firefox, βασισμένο σε μια κοινότητα χιλιάδων ανθρώπων απ' όλο τον κόσμο, με το 40% του κώδικα του να είναι γραμμένο ακόμα και σήμερα από εθελοντές, με μεταφράσεις σε πάνω από 70 γλώσσες γραμμένες σχεδόν αποκλειστικά από εθελοντές, με χιλιάδες ανθρώπους που δοκιμάζουν και ελέγχουν τις νέες εκδόσεις πριν αυτές γίνουν επίσημες και χιλιάδες υποστηρικτές του να τον διαδίδουν από στόμα σε στόμα και να προσφέρουν βοήθεια σε νέους χρήστες.

Φυσικά αυτό το μοντέλο του ελεύθερου/ανοικτού κώδικα λογισμικού προϋπήρχε, αλλά ο Mozilla Firefox κατάφερε να το βάλει στα μηχανήματα πάνω από 330 εκατομμυρίων χρηστών παγκοσμίως.

Και δεν είναι το μόνο πρόγραμμα ελεύθερου/ανοικτού λογισμικού, υπάρχουν χιλιάδες άλλα που περιμένουν να τα ανακαλύψετε όπως το OpenOffice ή το λειτουργικό σύστημα ubuntu που περιλαμβάνουν και τα μαθητικά netbook.

Καταφέραμε μέσα σ' αυτό το διάστημα να ανοίξουμε ξανά μια αγορά που κυριαρχούνταν μονοπωλιακά από ένα προϊόν, όχι επειδή ήταν το καλύτερο αλλά απλά επειδή καμία εταιρία δεν μπορούσε να το ανταγωνιστεί με ίσους όρους, προσφέροντας ξανά το δικαίωμα της επιλογής στον καθένα για το πως θέλει να βλέπει τον ιστό.H ανάπτυξη και η γιγάντωση της χρήσης του Firefox, δίνει ώθηση και στην υιοθέτηση ανοιχτών προτύπων στο Ελληνικό διαδίκτυο.

Στο παρελθόν, δημόσιες υπηρεσίες και εταιρίες κατασκεύαζαν τις ιστοσελίδες τους και διένειμαν το περιεχόμενο με τέτοιο τρόπο ώστε να είναι προσβάσιμες μόνο από συγκεκριμένο λειτουργικό σύστημα και τον περιηγητή ιστοσελίδων που το συνόδευε, αγνοώντας την ύπαρξη άλλων λειτουργικών συστημάτων και εφαρμογών.

Σήμερα, η συντριπτική πλειοψηφία των ιστοσελίδων είναι συμβατές με τα διεθνή πρότυπα, και προσβάσιμες από όλους τους Έλληνες χρήστες ανεξαρτήτως του λειτουργικού συστήματος που χρησιμοποιούν.

Η περαιτέρω υιοθέτηση των ανοικτών προτύπων και στην διανομή του περιεχομένου είναι ένα από τα πιο σημαντικά κεφάλαια για την ισότιμη πρόσβαση στην πληροφόρηση και τη γνώση.

Ανοικτά πρότυπα όπως το open document format (odf) για τα έγγραφα, το Ogg format και οι codecs Theora και Vorbis για την αναπαραγωγή βίντεο εξασφαλίζουν την διαλειτουργικότητα των συστημάτων και την ελεύθερη πρόσβαση στην πληροφορία από όλους.

Το Ελεύθερο Λογισμικό είναι ένα απαραίτητο συστατικό στη διατήρηση των Ανοιχτών Προτύπων εναντίον του οικονομικού κινήτρου της ιδιοποίησης ή της παρέκκλισης από τα Ανοιχτά Πρότυπα και ο Mozilla Firefox ως κομμάτι του ελεύθερου λογισμικού είχε κι έχει πάντα ως στόχο να είναι το διαδίκτυο ανοικτό και προσβάσιμο από όλους,

Ας δούμε λοιπόν μαζί μερικές από τις ημερομηνίες-σταθμούς στην κοινή μας πορεία:

  • Γύρω στα τέλη του 2002 δημιουργήθηκε ο Phoenix, σαν μια προσπάθεια να αυτονομηθεί ο περιηγητής από την πλήρη εφαρμογή Mozilla suite (διάδοχο του Netscape Navigator suite).

  • Στα μέσα του 2003 , ο οργανισμός mozilla αποφασίζει την στήριξη της ανάπτυξης ξεχωριστών εφαρμογών για περιήγηση και ηλεκτρονικό ταχυδρομείο και αποφασίζεται η αλλαγή του ονόματος σε Mozilla Firebird.

  • Στις αρχές του 2004 αποφασίζεται μια ακόμα αλλαγή του ονόματος και ο Mozilla Firebird γίνεται ο γνωστός σε όλους μας πια Mozilla Firefox για να ακολουθήσει λίγο πριν το τέλος της ίδιας χρονιάς η έκδοση 1.0 στις 9 Νοεμβρίου μεταφρασμένή ήδη σε 29 γλώσσες.

    Την πρώτη κιόλας μέρα έχουν πραγματοποιηθεί 1 εκατομμύριο λήψεις.

  • Σχεδόν ένα χρόνο αργότερα, εκδίδεται ο Mozilla Firefox 1.5 που προσφέρει αυτόματη ενημέρωση, βελτιωμένες ρυθμίσεις ασφαλείας και είναι μεταφρασμένος σε 32 γλώσσες.

  • Τον Οκτώβριο του 2006 βγαίνει ο Mozilla Firefox 2.0 μεταφρασμένος σε 37 γλώσσες και μέσα σε 24 ώρες τρέχει στα μηχανήματα πάνω από δυο εκατομμυρίων χρηστών.

  • Τον Ιούνιο του 2008 εκδίδεται ο Mozilla Firefox 3.0 και κατακτά το παγκόσμιο ρεκόρ Guinness για τον μεγαλύτερο αριθμό λήψεων μέσα σε 24 ώρες.

    Λίγο αργότερα ανακοινώνονται τα σχέδια για τη δημιουργία μιας έκδοσης του Firefox για κινητά με την κωδική ονομασία Fennec.

  • Ένα χρόνο μετά, τον Ιούνιο του 2009 εκδίδεται ο Mozilla Firefox 3.5 μεταφρασμένος σε 73 γλώσσες, υποστήριξη για HTML5 και ανοιχτούς τύπους βίντεο και ήχου.

  • Στις 31 Οκτωβρίου 2009 διατέθηκε η πρώτη δοκιμαστική έκδοση του Mozilla Firefox 3.6 και σύντομα θα είναι διαθέσιμη και η επίσημη.

Σήμερα, το μερίδιο αγοράς του Mozilla Firefox στην Ελλάδα έχει φτάσει στο 44,11% (πηγή: statcounter), μια επίδοση που ξεπερνά κατά πολύ τον ευρωπαϊκό και παγκόσμιο μέσο όρο.

Μια επίδοση που οφείλετε στην εμπιστοσύνη, την πίστη και την αγάπη που όλοι εμείς οι χρήστες του Mozilla Firefox δείξαμε και συνεχίζουμε να δείχνουμε στο ελεύθερο πνεύμα και τις κορυφαίες επιδόσεις του.

Γι' αυτό σας καλούμε όλους να γιορτάσετε μαζί μας αυτά τα πέντε πρώτα χρόνια και να ευχηθούμε όλοι μαζί πολλά περισσότερα!