summaryrefslogtreecommitdiffstats
path: root/client/engine/Cache.lib
diff options
context:
space:
mode:
authorramon <ramongomez@us.es>2012-06-18 08:03:55 +0000
committerramon <ramongomez@us.es>2012-06-18 08:03:55 +0000
commit5792125769e55caa24cb660c9d3ac7843bc8110f (patch)
tree01d9ef255c98d9abf0ed822a32781cd643f080e4 /client/engine/Cache.lib
parentc31a439952f871cb74601a26778724cab632b7d7 (diff)
Versión 1.0.4, #543: Función {{{ogCreateCache}}} para discos vacíos; corregir varias erratas en motor de clonación.
git-svn-id: https://opengnsys.es/svn/branches/version1.0@3216 a21b9725-9963-47de-94b9-378ad31fedc9
Diffstat (limited to 'client/engine/Cache.lib')
-rwxr-xr-xclient/engine/Cache.lib22
1 files changed, 14 insertions, 8 deletions
diff --git a/client/engine/Cache.lib b/client/engine/Cache.lib
index d1d2e881..118bc65b 100755
--- a/client/engine/Cache.lib
+++ b/client/engine/Cache.lib
@@ -31,25 +31,26 @@
function ogCreateCache ()
{
# Variables locales.
-local FINDCACHE NDSK PART DISK START END ENDPREVPART SIZE MINSIZE MAXSIZE ID
+local FINDCACHE NDSK PART DISK START END ENDPREVPART SIZE MINSIZE MAXSIZE PTTYPE ID
# Si se solicita, mostrar ayuda.
if [ "$*" == "help" ]; then
ogHelp "$FUNCNAME" "$FUNCNAME int_partsize" "$FUNCNAME 10000000"
return
fi
-# Error si no se recibe 1 parámetro.
+# Error si no se recibe 1 parámetro que sea un número entero.
[ $# == 1 ] || ogRaiseError $OG_ERR_FORMAT || return $?
+[[ $1 =~ ([0-9]*) ]] || ogRaiseError $OG_ERR_FORMAT "$1" || return $?
FINDCACHE="1 4" # Partición de caché (ndisco npart).
NDSK=${FINDCACHE% *}
PART=${FINDCACHE#* }
DISK=$(ogDiskToDev $NDSK) || return $?
-END=$(ogGetLastSector $NDSK) # Sector final del disco.
-SIZE=$(echo $1|awk '{print $0*2}') # En sectores de 512 B.
+END=$[$(ogGetLastSector $NDSK 2>/dev/null)] # Sector final del disco.
+SIZE=$[$1*2] # Tamaño en sectores de 512 B.
START=$[END-SIZE+1]
-ENDPREVPART=$(ogGetLastSector $NDSK $[PART-1])
+ENDPREVPART=$[$(ogGetLastSector $NDSK $[PART-1] 2>/dev/null)]
# Error si tamaño no está entre límites permitidos o si se solapa con la partición anterior.
-MINSIZE=100000 # Error de formateo si tamaño < 50 MB.
+MINSIZE=25000 # Error de formateo si tamaño < 50 MB.
MAXSIZE=$[END/2] # No permitir tamaño > mitad del disco.
if [ $SIZE -lt $MINSIZE -o $SIZE -gt $MAXSIZE -o $START -le $ENDPREVPART ]; then
ogRaiseError $OG_ERR_FORMAT "$1" || return $?
@@ -58,8 +59,13 @@ fi
# Desmontar todos los sistemas de archivos del disco.
ogUnmountAll 1 2>/dev/null
# Definir particiones y notificar al kernel.
-# En el caso de ser disco GPT, de momento se borra la particion y se vuelve a crear por
-# lo que se pierden los datos.
+# En el caso de ser disco GPT, de momento se borra la particion y se vuelve a crear,
+# por lo que se pierden los datos.
+PTTYPE=$(ogGetPartitionTableType $NDSK)
+if [ -z "$PTTYPE" ]; then
+ PTTYPE="MSDOS" # Por defecto para discos vacíos.
+ ogCreatePartitionTable $NDSK $PTTYPE
+fi
case "$(ogGetPartitionTableType $NDSK)" in
GPT)
# Si la tabla de particiones no es valida, volver a generarla.