source: client/engine/System.lib @ 1c04494

918-git-images-111dconfigfileconfigure-oglivegit-imageslgromero-new-oglivemainmaint-cronmount-efivarfsmultivmmultivm-ogboot-installerogClonningEngineogboot-installer-jenkinsoglive-ipv6test-python-scriptsticket-301ticket-50ticket-50-oldticket-577ticket-585ticket-611ticket-612ticket-693ticket-700ubu24tplunification2use-local-agent-oglivevarios-instalacionwebconsole3
Last change on this file since 1c04494 was 8964f9b, checked in by ramon <ramongomez@…>, 16 years ago

Resstructuración de trunk.

git-svn-id: https://opengnsys.es/svn/trunk@390 a21b9725-9963-47de-94b9-378ad31fedc9

  • Property mode set to 100755
File size: 3.4 KB
Line 
1#!/bin/bash
2#/**
3#@file     System.lib
4#@brief    Librería o clase System
5#@class    System
6#@brief    Funciones básicas del sistema.
7#@version  0.9
8#@warning  License: GNU GPLv3+
9#*/
10
11
12#/**
13#         ogEcho [loglevel] message...
14#@brief   Muestra mensajes en consola y lo registra en fichero de incidencias.
15#@arg  \c str_loglevel nivel de registro de incidencias.
16#@arg  \c str_message  mensaje (puede recibir más de 1 parámetro.
17#@return  Mensaje mostrado.
18#@note    El nivel de ayuda \c (help) no se registra en el fichero de incidencias.
19#@version 0.9 - Primera versión para OpenGNSys
20#@author  Ramon Gomez, ETSII Universidad de Sevilla
21#@date    2009-07-23
22#*/
23function ogEcho () {
24
25# Variables locales
26local LOGLEVEL LOGFILE DATETIME
27
28#/// Selección del nivel de registro (opcional).
29case "$1" in
30     help)    shift ;;
31     info)    LOGLEVEL=$1; shift ;;
32     warning) LOGLEVEL=$1; shift ;;
33     error)   LOGLEVEL=$1; shift ;;
34     *)       ;;
35esac
36 
37#/// Registro de incidencias.
38#[ -w "$OGLOGFILE" ] && LOGFILE="-f $OGLOGFILE"
39#DATETIME=$(date +"%F %T")    # pendiente en cliente Initrd
40if [ -n "$LOGLEVEL" ]; then
41    logger -s -t "OpenGNSys $LOGLEVEL" $LOGFILE "$DATETIME $*"
42else
43    echo "$*"
44fi
45}
46
47
48#/**
49#         ogRaiseError errcode ["errmessage" ...]
50#@brief   Devuelve el mensaje y el código de error correspondiente.
51#@arg  \c int_errcode    código de error.
52#@arg  \c str_errmessage mensajes complementarios de error.
53#@return  Mensaje de error.
54#@warning No definidas
55#@note    Mensajes internacionales del fichero de idiomas.
56#@version 0.9 - Primera versión para OpenGNSys.
57#@author  Ramon Gomez, ETSII Universidad de Sevilla
58#@date    2009-07-21
59#*/
60function ogRaiseError () {
61
62# Variables locales
63local MSG CODE
64
65#/// Obtener código y mensaje de error.
66CODE=$1
67case "$CODE" in
68     $OG_ERR_FORMAT)    MSG="$MSG_ERR_FORMAT $*" ;;
69     $OG_ERR_NOTFOUND)  MSG="$MSG_ERR_NOTFOUND \"$2\"" ;;
70     $OG_ERR_PARTITION) MSG="$MSG_ERR_PARTITION \"$2\"" ;;
71     $OG_ERR_LOCKED)    MSG="$MSG_ERR_LOCKED \"$2\"" ;;
72     $OG_ERR_IMAGE)     MSG="$MSG_ERR_IMAGE \"$2\"" ;;
73     $OG_ERR_NOTOS)     MSG="$MSG_ERR_NOTOS \"$2\"" ;;
74     $OG_ERR_NOTEXEC)   MSG="$MSG_ERR_NOTEXEC \"$2\"" ;;
75     *)                 MSG="$MSG_ERR_GENERIC"; CODE=$OG_ERR_GENERIC ;;
76esac
77
78#/// Mostrar mensaje de error y salir con el código indicado.
79ogEcho error "${FUNCNAME[1]}: $MSG" >&2
80return $CODE
81}
82
83
84#/**
85#         ogHelp ["function" ["format" ["example" ... ]]]
86#@brief   Muestra mensaje de ayuda para una función determinda.
87#@arg  \c str_function Nombre de la función.
88#@arg  \c str_format   Formato de ejecución de la función.
89#@arg  \c str_example  Ejemplo de ejecución de la función.
90#@return  Salida de ayuda.
91#@note    Si no se indican parámetros, la función se toma de la variable \c $FUNCNAME
92#@note    La descripción de la función se toma de la variable compuesta por \c MSG_FUNC_$función incluida en el fichero de idiomas.
93#@note    Pueden especificarse varios mensajes con ejemplos.
94#@version 0.9 - Primera versión para OpenGNSys.
95#@author  Ramon Gomez, ETSII Universidad de Sevilla
96#@date    2009-07-27
97#*/
98function ogHelp () {
99
100# Variables locales.
101local FUNC MSG
102
103#/// Mostrar función, descripción y formato.
104FUNC="${1:-${FUNCNAME[${#FUNCNAME[*]}-1]}}"
105MSG="MSG_HELP_$FUNC"
106ogEcho help "$MSG_FUNCTION $FUNC: ${!MSG}"
107[ -n "$2" ] && ogEcho help "    $MSG_FORMAT: $2"
108#/// Mostrar ejemplos.
109shift 2
110while [ $# -gt 0 ]; do
111    ogEcho help "    $MSG_EXAMPLE: $1"
112    shift
113done
114}
115
Note: See TracBrowser for help on using the repository browser.