/usr/share/pyshared/Editeur/uiinfo.py is in eficas 6.4.0-1-1.1.
This file is owned by root:root, with mode 0o644.
The actual contents of the file can be viewed below.
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 | # -*- coding: utf-8 -*-
# CONFIGURATION MANAGEMENT OF EDF VERSION
# ======================================================================
# COPYRIGHT (C) 1991 - 2002 EDF R&D WWW.CODE-ASTER.ORG
# THIS PROGRAM IS FREE SOFTWARE; YOU CAN REDISTRIBUTE IT AND/OR MODIFY
# IT UNDER THE TERMS OF THE GNU GENERAL PUBLIC LICENSE AS PUBLISHED BY
# THE FREE SOFTWARE FOUNDATION; EITHER VERSION 2 OF THE LICENSE, OR
# (AT YOUR OPTION) ANY LATER VERSION.
#
# THIS PROGRAM IS DISTRIBUTED IN THE HOPE THAT IT WILL BE USEFUL, BUT
# WITHOUT ANY WARRANTY; WITHOUT EVEN THE IMPLIED WARRANTY OF
# MERCHANTABILITY OR FITNESS FOR A PARTICULAR PURPOSE. SEE THE GNU
# GENERAL PUBLIC LICENSE FOR MORE DETAILS.
#
# YOU SHOULD HAVE RECEIVED A COPY OF THE GNU GENERAL PUBLIC LICENSE
# ALONG WITH THIS PROGRAM; IF NOT, WRITE TO EDF R&D CODE_ASTER,
# 1 AVENUE DU GENERAL DE GAULLE, 92141 CLAMART CEDEX, FRANCE.
#
#
# ======================================================================
"""
Ce module sert à construire les structures de données porteuses
des informations liées aux groupes de commandes
"""
import types
class UIINFO:
"""
Pour le moment la classe UIINFO ne sait traiter que des infos
portant sur la definition des groupes de commandes
Les autres informations sont ignorées
"""
def __init__(self,parent,groupes=None,**args):
"""
Initialiseur de la classe UIINFO.
Initialise a partir du dictionnaire UIinfo passé à
un objet ENTITE les attributs de la classe
"""
# L'attribut parent stocke le lien vers l'objet ENTITE relié à UIINFO
self.parent=parent
self.groupes=groupes
if groupes == None:
# L'entite n'a pas de groupe associé. On lui associe le groupe "DEFAUT"
self.groupes=("DEFAUT",)
if type(self.groupes) != types.TupleType:
self.groupes=(self.groupes,)
def traite_commande(commande,niveau):
"""
Cette fonction cree l'attribut UI de l'objet commande
à partir des informations contenues dans UIinfo
"""
uiinfo=commande.UIinfo or {}
UI=UIINFO(commande,**uiinfo)
commande.UI=UI
#if "CACHE" in UI.groupes:
# La commande est cachee aux utilisateurs
#niveau.dict_groupes["CACHE"].append(commande.nom)
#pass
#else:
# On ajoute la commande dans tous les groupes specifies
for grp in UI.groupes:
if not niveau.dict_groupes.has_key(grp): niveau.dict_groupes[grp]=[]
niveau.dict_groupes[grp].append(commande.nom)
def traite_niveau(niveau):
if niveau.l_niveaux == ():
# Il n'y a pas de sous niveaux. niveau.entites ne contient que des commandes
niveau.dict_groupes={}
for oper in niveau.entites:
traite_commande(oper,niveau)
# A la fin les cles du dictionnaire dict_groupes donnent la liste des groupes
# sans doublon
niveau.liste_groupes=niveau.dict_groupes.keys()
# On ordonne les listes alphabétiquement
niveau.liste_groupes.sort()
for v in niveau.dict_groupes.values():v.sort()
#print niveau.liste_groupes
#print niveau.dict_groupes
else:
for niv in niveau.l_niveaux:
traite_niveau(niv)
def traite_UIinfo(cata):
"""
Cette fonction parcourt la liste des commandes d'un catalogue (cata)
construit les objets UIINFO à partir de l'attribut UIinfo de la commande
et construit la liste complète de tous les groupes présents
"""
#dict_groupes["CACHE"]=[]
#XXX Ne doit pas marcher avec les niveaux
if cata.JdC.l_niveaux == ():
# Il n'y a pas de niveaux
# On stocke la liste des groupes et leur contenu dans le JdC
# dans les attributs liste_groupes et dict_groupes
cata.JdC.dict_groupes={}
for commande in cata.JdC.commandes:
traite_commande(commande,cata.JdC)
# A la fin les cles du dictionnaire dict_groupes donnent la liste des groupes
# sans doublon
cata.JdC.liste_groupes=cata.JdC.dict_groupes.keys()
# On ordonne les listes alphabétiquement
cata.JdC.liste_groupes.sort()
for v in cata.JdC.dict_groupes.values():v.sort()
#print cata.JdC.liste_groupes
#print cata.JdC.dict_groupes
else:
# Le catalogue de commandes contient des définitions de niveau
for niv in cata.JdC.l_niveaux:
traite_niveau(niv)
|