GNOME.ORG

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

January 22, 2020

7 tips to survive booth duty at a conference-events

Tips to survive booth duty at a conference-events

If you contribute to an open-source community, there will be an "opportunity" that you will represent the community to a conference. You're expected to staff the booth and talk to people about the software.

For some people, it looks like you are traveling and having fun. I have news for you. It's not like that.
We are going to see some tips on how to survive the booth duty.


1. Contact the booth manager

If you're not the booth manager (usually you're not), then you need to contact him/her before you travel. This person is in charge of shipping all the swag to the exhibition-conference hall at the right time, getting everything put together and taking things down afterward. Usually, this person organizes the shifts at the booth. So you have to check when you can have your brake, ask if there is a special "strategy" to promote, etc.


2. Clothes

Make sure with the booth manager if there is a dress code (so you need to carry a suit). If not, then make sure about the same T-shirt. Wear a comfortable top (T-shirt or hoodie) with the project's logo. It's good for the project that when you'll have a break or when you go for a walk to check other booths, you "advertise" the project. There might be people to see the logo and ask you, so you can point them to your booth.
Carry with you another T-shirt just in case of an emergency, so you can change (also carry a deodorant).
Regarding pants, wear also something comfortable. Jeans are fine but if it's summer, then a short is OK.


3. Shoes

Wear comfy shoes. This is the most important tip. You are going to spend a lot of time standing up. Most of the conferences are 2 days long, so you're going to be getting very sore feet. A pair of shoes with cushioned soles are the perfect choice for the situation. If there is a dress code, then be sure to wear high heels during your central presentation and then have a second pair of shoes for your booth duty.


4. Help with setup/breakdown

If you're not an employee of the open-source project company, then usually the company behind the project (or the companies that sponsor your open source project), paid part of your expenses. They expect you to stuff the booth but also to help them set up everything before and breakdown everything after the conference. Having good "relation" with the booth manager means also help with these activities. Ask questions like: "Where would you like this?" or "May I carry anything?". Be different from the people who turned up two minutes before the show was due to start and made ill-advised remarks about the sign not being entirely straight on the front desk.


5. Don't over-police the swag

Swag means "give-aways". Usually, swag is a discussion opener. If the visitor is aware of your project, then he/she wants to get stickers for the laptop. Let them get more that one, because they usually get some for people back home, for people who cannot attend the conference or for LUG members. Experienced marketers realize they'll just need to box everything up at the end and ship it back, so they might as well give as much of it away as possible.


6. Save some swag for the second day

Most conferences have the majority of visitors during the first day. Usually, they get most (sometimes all) of the swag. The project run out of some swag the second day. That's good because, during the breakdown, there are fewer items to ship back to the company's office. But it's bad because the visitors on the second day, won't be able to get some swag. So save some for the second day (Pareto principle: let's say 80% the first day and 20% the second day). If you have some swag left before the breakdown, take a selection of your best swag around to other booths on the floor and see what you can swap. Your project's swag may seem utterly useless to you, but there's a good chance (particularly if your marketing people know their thing) that other people might want it and will be willing to give you some of their swag in return.


7. You need a big suitcase

In other words, you need an empty big suitcase. Why? Because you'll get swag from other projects or even from your project to use back home, to share with other open-source friends-communities who couldn't attend where you've been.

Regarding how to behave at the booth, you can check the video from an openSUSE conference:


And another from my friend Jos:

January 13, 2020

How to survive a health crisis during a FOSS conference

How to survive a health crisis during a FOSS conference

The title describes everything. This is not only for FOSS conferences but events in general. Attending a conference means to meet friends (usually you meet once a year) and have fun in general.

The organizers are responsible for everything that happens during the conference hours. We are grown people, so we have to be responsible for the rest of the day. Sometimes bad things might happen (bad: the critical meaning is health issues). Although the organizers aren't responsible for that, they are the key people, who know the system in their country and it's a good and human thing to help the person with the problem. Everyone wants to have fun and be happy at the end of the conference.

Being an organizer and volunteer, I felt the frustration of having everything covered. I lived a couple of times the health crisis during the conference.

Here are some points to cover before and during the conference. Please leave a comment if you want to share your experience.

Before the conference:


0. If the conference takes place within European Union, you can ask the European citizens to get the European Insurance Card. It doesn't cover everything, but at least you'll avoid some stupid bureaucracy. If they're not EU citizens or they don't have insurance, ask them to buy one for their trip. Usually, when you buy the plane ticket, they suggest buying a medical insurance. Do it, because it will save you from a lot of trouble.

1. During the online registration, ask for an emergency contact (ask for name and phone number). It will help you and doctors just in case they need the medical history of the person, the allergies, etc.

2. If they're not feeling comfortable to provide name and number, ask them to enable a feature of emergency call on their phone or even better to install a program with the emergency call and some medical history and their medication. Personally I have the Medical ID (Free) installed (you can choose other). It will help the doctors because it has a field to add your medical history so they can treat you correctly.

3. This might be very personal, but ask them to enter where they will stay. You might need to go to their hotel and bring a special medication they "forgot" to bring with them. And that leads to another issue. Ask them to bring the medication at the conference with them.

4. During registration, it's good to have a field for write down a disease that the attendee feels comfortable to share. There is the code of conduct committee that can guarantee this information. For example, if the attendee has epilepsy, it's good for the organizers to know and be prepared. Usually, people with epilepsy tell that information to their friends, so they won't be surprised just in case of a seizure.

5. During registration, ask for special types of food. It's not the only religion that prohibits some kinds of food but there are some other categories such as vegan, vegetarian, gluten-free, etc. Some of them are just a way of life but others are health-related.

6. Gather information and write on the web site everything health-related that the attendees must know because usually there are some illnesses that come up after the attendees return back home. A special quote is if there are special vaccines that the attendees have to be vaccinated. It's better for the locals to write down

7. Gather information and write on the web site what everyone has to be careful. Examples are, don't drink tap water, buy water from kiosks and that costs ..., don't walk alone after midnight at that place because you might get robbed, smoking pot is illegal, traffic police violations. Find out what the attendees need to know so they won't end up either at the hospital or police station.

8. Every country has a different health system. Make sure that you find out the hospitals that accept emergencies and also the pharmacies that are open during the night. Make a list with details (address, phone number, specialties, etc) for the days of the conference. It's better not to use it rather not have it at all.

9. Gather all addresses and phone numbers of embassies and consulates of the attendees. It's the place they have to call if they have a problem and there are people they speak the same language that can help them.

10. On the name tags, write down the emergency phone numbers (like 112). In my country it's different for the police, fire department, ambulance. Also, buy a disposable cell phone number and put the number on the name tags, so attendees can call a local that knows the system and can help.

11. Contact Red Cross volunteers. I guess there are different organizations for every country. You can search for their information. They might be present during the conference for free. They are people with jobs and they are volunteers, so if they cannot join you, ask them to train someone for some basics.

12. Write a document "Protocol if we have to call the authorities". That includes everything from fire to ambulance and from the police to traffic police. Of course, you cannot include everything (because you never know) but at least you can act for some basic situations.


During the conference:


1. Keep a central booth for Red Cross volunteers. They usually carry a bag with heavy equipment. Ask them how they want to have communication for emergencies. Usually, many venues have defibrillators (I think it's called like that). So help them to find one. Ask the volunteers what else they need to operate. Don't forget they are volunteers, so please make sure they have free food and water and maybe you can give them a T-shirt of your project for free.

2. Make sure you have a private room that the Red Cross volunteers can examine someone. That can be an office. Nothing fancy. Usually, people don't like to be examined in public. Also, the Red Cross Volunteers are more concentrated when the place is quiet.

3. If you don't have a Red Cross volunteer, try to train someone or find a key person (name and phone number) who knows CPR, how to use a defibrillator, etc. He might save a life before the ambulance arrives.

4. Have an Emergency mobile number that an attendee can call you when he faces a problem. Have in mind that everything will happen during the night (because people tend to do stupid things during the night). So be prepared to go to the police (got robbed or had a fight with a local etc), go to a hospital (got hit by a local or got a bicycle and fell, etc). As I wrote, the organizers aren't responsible for what happens after the conference hours. But leaving someone who doesn't know how the foreign system works, it will be bad for you and the organization in general. So make shifts for locals on call :-)

5. Try to pass everything as quite as you can. It's not good to make a fuss out of the incident. The person with the problem doesn't like everyone to see and ask if he's OK or feel pity for him. That's why the private room helps.


If you have an idea that I forgot, please leave a comment. Please share it with people that organize conferences because it might give them some tips.

Some of the above ideas are overdone. It's better to be prepared rather than be stressed.
I hope following all or some of the above will lead you to a successful conference.

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 Open-tran.eu 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

Documentation:
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 ?
Read more...

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 είναι έτοιμο, έχουμε προσδιορίσει ότι θα χρειαστούμε και το σώζουμε σαν volumecontrol.glade. Το πρόγραμμα μας σε python είναι απλό και περιέχει στοιχεία που έχουμε δει ήδη.

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

import os
try:
    import alsaaudio
    HAVEALSA=True
except:
    import subprocess
    import commands
    HAVEALSA=False
import pygtk
pygtk.require('2.0')
import gtk

class VolumeControl():

    def __init__(self):
        builder=gtk.Builder()
        builder.add_from_file("volumecontrol.glade")
        builder.connect_signals(self)
        self.window = builder.get_object("volumewindow")
        self.window_position = (0, 0)
        self.staticon = builder.get_object("staticon")
        self.menu = builder.get_object("menu")
        self.masterslider = builder.get_object("masterslider")

    def close_window(self, widget, data=None):
        gtk.main_quit()

    def button_clicked(self, widget):
        os.system('gnome-alsamixer')

    def window_show(self, widget, data=None):
        if self.window.get_property('visible'):
            self.window.hide()
        else:
            self.masterslider.set_value(self.get_master_volume())
            self.set_window_position()
            self.window.move(self.window_position[0], self.window_position[1])
            self.window.show_all()
            self.window.present()
           
    def menu_popup(self, widget, button, time, data = None):
        if button == 3:
            self.menu.show_all()
            self.menu.popup(None, None, None, 3, time)

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

    def set_window_position(self):
        staticon_geometry = self.staticon.get_geometry()[1]
        if staticon_geometry.y <= 200:
            y_coords = staticon_geometry.y
        else:
            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]
        else:
            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_version('1.0')
        about.set_comments(u'Πρόγραμμα ελέγχου της στάθμης του ήχου.')
        about.run()
        about.destroy()

    def main(self):
        gtk.main()

if __name__ == "__main__":
    app=VolumeControl()
    app.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):
        encodings=CODEPAGES
        if codefrom:
            encodings=[codefrom]
        for enc in encodings:
            t1=codecs.open(self.fn,'r',enc)
            try:
                line=t1.readline()
                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]
                self.cp=enc
                t1.close()
                ret=True
                break
            except:
                ret=False
        return ret    

class ConvertFiles(object):

    def close_window(self, widget, data=None):
        gtk.main_quit()

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

    def aboutmenu_clicked(self, widget, data=None):
        self.aboutdialog.run()
        self.aboutdialog.hide()

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

    def openmenu_clicked(self, widget, data=None):
        self.filechooser.show()

    def filterbox_changed(self, widget, data=None):
        if widget.get_active() == 0:
            self.filechooser.set_filter(self.txtfilter)
        if widget.get_active() == 1:
            self.filechooser.set_filter(self.srtfilter)
        if widget.get_active() == 2:
            self.filechooser.set_filter(self.allfilter)              

    def filelistview_key(self, widget, data=None):
        treeviewmodel, treeviewindex = widget.get_selection().get_selected()
        if (gtk.gdk.keyval_name(data.keyval) == 'Delete') and treeviewindex:
            treeviewmodel.remove(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):
        self.filechooser.hide()

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

    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)
        dialog.set_title(u"Σφάλμα")
        dialog.set_markup(u"<b>"+errortxt+"</b>")
        response=dialog.run()
        if response == gtk.RESPONSE_DELETE_EVENT or response == gtk.RESPONSE_OK:
           dialog.destroy()

    def savemenu_clicked(self, widget, data=None):
        errortxt=''
        if not self.files:
            self.errordialog(u"Δεν έχετε επιλέξει αρχεία.\n")
            return
        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.errordialog(errortxt)
            self.statusbar.push(0,u"Δεν ήταν σωστή η κωδικοποίηση που ορίσατε.")
            return
        for i in range(len(self.files)):
            self.files[i].to_cp=CODEPAGES[self.codetobox.get_active()]
            self.files[i].to_eol=EOL[self.eolbox.get_active()]
        treeiter=self.filelist.get_iter_first()
        for fi in self.files:
            try:
                t1=codecs.open(fi.fn,'r',fi.cp)
                t2=codecs.open('tmp','w',fi.to_cp)
                for line in t1:
                    line=line.replace(DICT_EOL[fi.eol],DICT_EOL[fi.to_eol])
                    t2.write(line)
                t2.close()
                t1.close()
                os.rename('tmp',fi.fn)
            except:
                self.errordialog(u"Πρόβλημα στην μετατροπή του %s.\n" % fi.fn)
                success=False
            else:
                if fi.checkfile():
                    self.filelist.set_value(treeiter,1,fi.cp)
                    self.filelist.set_value(treeiter,2,fi.eol)
                    fi.to_cp = ''
                    fi.to_eol = ''
                    success=True
                else:
                    self.errordialog(u"Πρόβλημα στην τελική ανάγνωση του %s.\n" % fi.fn)
                    success=False
            treeiter=self.filelist.iter_next(treeiter)
        if success:
            self.statusbar.push(0,u"Επιτυχής μετατροπή")
        else:
            self.statusbar.push(0,u"Προβλήματα στην μετατροπή")
     
    def __init__(self):
        builder = gtk.Builder()
        builder.add_from_file("convert.glade")
        builder.connect_signals(self)
        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")
        self.codefromlist.append([u"Μαντεψιά"])
        for item in CODEPAGES:
            self.codefromlist.append([item])
            self.codetolist.append([item])
        for item in EOL:
            self.eollist.append([item])
        self.codefrombox.set_active(0)
        self.codetobox.set_active(0)
        self.eolbox.set_active(0)
        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")
        self.txtfilter.add_pattern('*.txt')
        self.txtfilter.add_pattern('*.TXT')
        self.srtfilter.add_pattern('*.srt')
        self.srtfilter.add_pattern('*.SRT')
        self.allfilter.add_pattern('*.*')
        self.filterbox_changed(self.filterbox)
        self.statusbar=builder.get_object("statusbar")
        self.files=[]
     
    def main(self):
        self.window.show()
        gtk.main()

if __name__== "__main__":
    app=ConvertFiles()
    app.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.


Εδώ θα θέλαμε να αναφέρουμε ορισμένα στοιχεία για την codecs.open. Αυτή όταν ανοίγει ένα αρχείο για διάβασμα το ανοίγει πάντα σε 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

Dock
Alternate-tab
Alternate-status-menu
Drive-menu
Places-menu
User-theme
User-theme-selector

Κάντε το 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

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

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

Alternate-tab

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

alt-tab-extension

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

Εγκατάσταση

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

Alternate-status-menu

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

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

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

places-1

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

User-theme

Το 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

themes-1

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

Ιστότοπος project: @ fpmurphy.com

Εγκατάσταση

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

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

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

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

Move the clock

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

apps-1

Favortites in panel

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

apps-2

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

apps-3

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

Εγκατάσταση

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

Χρήση του GnomeTweakTool

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

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

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 δεν έχουν ελεγχθεί,οι ονομασίες μπήκαν σε σχέση με αυτά που βρήκα στο http://rpm.pbone.net

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

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

February 11, 2010

Openoffice.org 3.2 is out!!



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

1) Ελληνικό OOo 3.2 για Linux x86 (rpm) ftp://ftp5.gwdg.de/pub/openoffice/localized/el/3.2.0/OOo_3.2.0_LinuxIntel_install_el.tar.gz
2) Ελληνικό OOo 3.2 για Linux x86 (rpm με jre) http://download.services.openoffice.org/files/localized/el/3.2.0/OOo_3.2.0_LinuxIntel_install_wJRE_el.tar.gz
3) Ελληνικό OOo 3.2 για Linux x86 (deb) ftp://ftp5.gwdg.de/pub/openoffice/localized/el/3.2.0/OOo_3.2.0_LinuxIntel_install_el_deb.tar.gz
4)Ελληνικό OOo 3.2 για Windows (με jre) http://download.services.openoffice.org/files/localized/el/3.2.0/OOo_3.2.0_Win32Intel_install_wJRE_el.exe
5)Ελληνικό OOo 3.2 για Windows (χωρίς jre) ftp://ftp5.gwdg.de/pub/openoffice/localized/el/3.2.0/OOo_3.2.0_Win32Intel_install_el.exe
6) Ελληνικό OOo 3.2 για MacOSX http://download.services.openoffice.org/files/localized/el/3.2.0/OOo_3.2.0_MacOSXIntel_install_el.dmg
7) Ελληνικό OOo 3.2 για Solaris Sparc http://download.services.openoffice.org/files/extended/3.2.0rc5/OOo_3.2.0rc5_20100203_SolarisSparc_install_wJRE_el.tar.gz
8) Ελληνικό OOo 3.1.1 για Solaris x86 http://download.services.openoffice.org/files/extended/3.2.0rc5/OOo_3.2.0rc5_20100203_Solarisx86_install_wJRE_el.tar.gz
9) Ελληνικό OOo 3.2 για Linux 64-bit RPM (με jre) http://download.services.openoffice.org/files/extended/3.2.0rc5/OOo_3.2.0rc5_20100203_LinuxX86-64_install_wJRE_el.tar.gz
10) Ελληνικό OOo 3.2 για Linux 64-bit deb http://download.services.openoffice.org/files/extended/3.2.0rc5/OOo_3.2.0rc5_20100203_LinuxX86-64_install_el_deb.tar.gz



ΟΔΗΓΙΕΣ ΕΓΚΑΤΑΣΤΑΣΗΣ linux:
(απεγκαταστήστε πρωτα την παλιά σας έκδοση)
Rpm:
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

deb:

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 χρονών!


09-11-2009



Σήμερα συμπληρώνονται πέντε χρόνια από την ημερομηνία κυκλοφορίας της πρώτης επίσημης έκδοσης του Mozilla Firefox (και μην ξε χάσετε να δείτε το εορταστικό βιντεάκι στο http://www.spreadfirefox.com/5years/el/ ).


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


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



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



Όταν η καθημερινή χρήση του διαδικτύου ήταν ένας επικίνδυνος ακροβατισμός ανάμεσα σε αναδυόμενα παράθυρα, ιούς, κενά ασφαλείας που παρέμεναν ανοιχτά για μήνες και συχνότατες καταρρεύσεις, ο 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 δείξαμε και συνεχίζουμε να δείχνουμε στο ελεύθερο πνεύμα και τις κορυφαίες επιδόσεις του.



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

Feeds