1995-04-27 18:05:10 +00:00
/*
* The new sysinstall program .
*
* This is probably the last attempt in the ` sysinstall ' line , the next
* generation being slated to essentially a complete rewrite .
*
1995-05-20 11:13:58 +00:00
* $ Id : media . c , v 1.10 1995 / 05 / 20 11 : 10 : 33 jkh Exp $
1995-04-27 18:05:10 +00:00
*
* Copyright ( c ) 1995
* Jordan Hubbard . All rights reserved .
*
* Redistribution and use in source and binary forms , with or without
* modification , are permitted provided that the following conditions
* are met :
* 1. Redistributions of source code must retain the above copyright
* notice , this list of conditions and the following disclaimer ,
* verbatim and that no modifications are made prior to this
* point in the file .
* 2. Redistributions in binary form must reproduce the above copyright
* notice , this list of conditions and the following disclaimer in the
* documentation and / or other materials provided with the distribution .
* 3. All advertising materials mentioning features or use of this software
* must display the following acknowledgement :
* This product includes software developed by Jordan Hubbard
* for the FreeBSD Project .
* 4. The name of Jordan Hubbard or the FreeBSD project may not be used to
* endorse or promote products derived from this software without specific
* prior written permission .
*
* THIS SOFTWARE IS PROVIDED BY JORDAN HUBBARD ` ` AS IS ' ' AND
* ANY EXPRESS OR IMPLIED WARRANTIES , INCLUDING , BUT NOT LIMITED TO , THE
* IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
* ARE DISCLAIMED . IN NO EVENT SHALL JORDAN HUBBARD OR HIS PETS BE LIABLE
* FOR ANY DIRECT , INDIRECT , INCIDENTAL , SPECIAL , EXEMPLARY , OR CONSEQUENTIAL
* DAMAGES ( INCLUDING , BUT NOT LIMITED TO , PROCUREMENT OF SUBSTITUTE GOODS
* OR SERVICES ; LOSS OF USE , DATA , LIFE OR PROFITS ; OR BUSINESS INTERRUPTION )
* HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY , WHETHER IN CONTRACT , STRICT
* LIABILITY , OR TORT ( INCLUDING NEGLIGENCE OR OTHERWISE ) ARISING IN ANY WAY
* OUT OF THE USE OF THIS SOFTWARE , EVEN IF ADVISED OF THE POSSIBILITY OF
* SUCH DAMAGE .
*
*/
1995-05-16 11:37:27 +00:00
# include <stdio.h>
# include "sysinstall.h"
1995-05-20 10:33:14 +00:00
static int
genericHook ( char * str , DeviceType type )
{
Device * * devs ;
/* Clip garbage off the ends */
string_prune ( str ) ;
str = string_skipwhite ( str ) ;
if ( ! * str )
return 0 ;
devs = deviceFind ( str , type ) ;
if ( devs )
mediaDevice = devs [ 0 ] ;
return devs ? 1 : 0 ;
}
static int
cdromHook ( char * str )
{
return genericHook ( str , DEVICE_TYPE_CDROM ) ;
}
1995-04-27 18:05:10 +00:00
/*
1995-05-16 02:53:31 +00:00
* Return 1 if we successfully found and set the installation type to
1995-04-27 18:05:10 +00:00
* be a CD .
*/
int
1995-05-01 21:56:32 +00:00
mediaSetCDROM ( char * str )
1995-04-27 18:05:10 +00:00
{
1995-05-20 03:49:10 +00:00
Device * * devs ;
1995-05-20 00:13:14 +00:00
int cnt ;
1995-05-20 10:33:14 +00:00
if ( OnCDROM = = TRUE ) {
/* XXX point mediaDevice at something meaningful here - perhaps a static device structure */
1995-05-16 02:53:31 +00:00
return 1 ;
1995-05-20 10:33:14 +00:00
}
1995-05-16 02:53:31 +00:00
else {
1995-05-20 03:49:10 +00:00
devs = deviceFind ( NULL , DEVICE_TYPE_CDROM ) ;
1995-05-20 00:13:14 +00:00
cnt = deviceCount ( devs ) ;
if ( ! cnt ) {
msgConfirm ( " No CDROM devices found! Please check that your system's \n configuration is correct and that the CDROM drive is of a supported \n type. For more information, consult the hardware guide \n in the Doc menu. " ) ;
return 0 ;
}
else if ( cnt > 1 ) {
1995-05-20 10:33:14 +00:00
DMenu * menu ;
menu = deviceCreateMenu ( & MenuMediaCDROM , DEVICE_TYPE_CDROM , cdromHook ) ;
if ( ! menu )
msgFatal ( " Unable to create CDROM menu! Something is seriously wrong. " ) ;
dmenuOpenSimple ( menu ) ;
free ( menu ) ;
1995-05-20 00:13:14 +00:00
}
1995-05-20 10:33:14 +00:00
else
1995-05-20 00:13:14 +00:00
mediaDevice = devs [ 0 ] ;
1995-05-16 02:53:31 +00:00
}
1995-05-20 10:33:14 +00:00
return mediaDevice ? 1 : 0 ;
}
static int
floppyHook ( char * str )
{
return genericHook ( str , DEVICE_TYPE_FLOPPY ) ;
1995-04-27 18:05:10 +00:00
}
1995-04-29 19:33:06 +00:00
/*
1995-05-16 02:53:31 +00:00
* Return 1 if we successfully found and set the installation type to
1995-04-29 19:33:06 +00:00
* be a floppy
*/
int
1995-05-01 21:56:32 +00:00
mediaSetFloppy ( char * str )
1995-04-29 19:33:06 +00:00
{
1995-05-20 10:33:14 +00:00
Device * * devs ;
int cnt ;
devs = deviceFind ( NULL , DEVICE_TYPE_FLOPPY ) ;
cnt = deviceCount ( devs ) ;
if ( ! cnt ) {
msgConfirm ( " No floppy devices found! Please check that your system's \n configuration is correct. For more information, consult the hardware guide \n in the Doc menu. " ) ;
return 0 ;
}
else if ( cnt > 1 ) {
DMenu * menu ;
menu = deviceCreateMenu ( & MenuMediaFloppy , DEVICE_TYPE_FLOPPY , floppyHook ) ;
if ( ! menu )
msgFatal ( " Unable to create Floppy menu! Something is seriously wrong. " ) ;
dmenuOpenSimple ( menu ) ;
free ( menu ) ;
}
else
mediaDevice = devs [ 0 ] ;
return mediaDevice ? 1 : 0 ;
1995-04-29 19:33:06 +00:00
}
/*
1995-05-16 02:53:31 +00:00
* Return 1 if we successfully found and set the installation type to
1995-04-29 19:33:06 +00:00
* be a DOS partition .
*/
int
1995-05-01 21:56:32 +00:00
mediaSetDOS ( char * str )
1995-04-29 19:33:06 +00:00
{
1995-05-16 02:53:31 +00:00
Device * * devs ;
1995-05-20 10:33:14 +00:00
Disk * d ;
Chunk * c1 ;
int i ;
1995-05-16 02:53:31 +00:00
1995-05-20 11:10:35 +00:00
devs = deviceFind ( NULL , DEVICE_TYPE_DOS ) ;
if ( devs ) {
/* XXX If count > 1 then at some point then we should put up a menu and allow the user to choose XXX */
mediaDevice = devs [ 0 ] ;
return 1 ;
}
else
devs = deviceFind ( NULL , DEVICE_TYPE_DISK ) ;
if ( ! devs ) {
1995-05-16 02:53:31 +00:00
msgConfirm ( " No disk devices found! " ) ;
1995-05-20 11:10:35 +00:00
return 0 ;
}
/* Now go chewing through looking for a DOS FAT partition */
1995-05-20 10:33:14 +00:00
for ( i = 0 ; devs [ i ] ; i + + ) {
d = ( Disk * ) devs [ i ] - > private ;
/* Now try to find a DOS partition */
for ( c1 = d - > chunks - > part ; c1 ; c1 = c1 - > next ) {
if ( c1 - > type = = fat ) {
/* Got one! */
1995-05-20 11:10:35 +00:00
mediaDevice = deviceRegister ( c1 - > name , c1 - > name , c1 - > name , DEVICE_TYPE_DOS , TRUE ,
1995-05-20 10:33:14 +00:00
mediaInitDOS , mediaGetDOS , mediaCloseDOS , NULL ) ;
msgDebug ( " Found a DOS partition %s on drive %s \n " , c1 - > name , d - > name ) ;
break ;
}
}
}
if ( ! mediaDevice )
msgConfirm ( " No DOS primary partitions found! This installation method is unavailable " ) ;
return mediaDevice ? 1 : 0 ;
1995-04-29 19:33:06 +00:00
}
/*
1995-05-16 02:53:31 +00:00
* Return 1 if we successfully found and set the installation type to
1995-04-29 19:33:06 +00:00
* be a tape drive .
*/
int
1995-05-01 21:56:32 +00:00
mediaSetTape ( char * str )
1995-04-29 19:33:06 +00:00
{
return 0 ;
}
/*
* Return 0 if we successfully found and set the installation type to
* be an ftp server
*/
int
1995-05-01 21:56:32 +00:00
mediaSetFTP ( char * str )
1995-04-29 19:33:06 +00:00
{
1995-05-16 11:37:27 +00:00
dmenuOpenSimple ( & MenuMediaFTP ) ;
1995-04-29 19:33:06 +00:00
return 0 ;
}
/*
* Return 0 if we successfully found and set the installation type to
* be some sort of mounted filesystem ( it ' s also mounted at this point )
*/
int
1995-05-01 21:56:32 +00:00
mediaSetFS ( char * str )
1995-04-29 19:33:06 +00:00
{
return 0 ;
}
1995-05-16 02:53:31 +00:00
FILE *
1995-05-16 11:37:27 +00:00
mediaOpen ( char * parent , char * me )
1995-05-16 02:53:31 +00:00
{
char fname [ FILENAME_MAX ] ;
if ( parent )
snprintf ( fname , FILENAME_MAX , " %s%s " , parent , me ) ;
else
1995-05-20 03:49:10 +00:00
snprintf ( fname , FILENAME_MAX , " %s/%s " , me , me ) ;
#if 0
1995-05-16 02:53:31 +00:00
strncpy ( fname , me , FILENAME_MAX ) ;
1995-05-20 03:49:10 +00:00
# endif
1995-05-20 00:13:14 +00:00
/* XXX mediaDevice points to where we want to get it from */
1995-05-16 11:37:27 +00:00
return NULL ;
}
Boolean
mediaExtractDist ( FILE * fp )
{
return TRUE ;
}
Boolean
mediaGetType ( void )
{
dmenuOpenSimple ( & MenuMedia ) ;
return TRUE ;
1995-05-16 02:53:31 +00:00
}
1995-05-16 11:37:27 +00:00
/* Return TRUE if all the media variables are set up correctly */
Boolean
mediaVerify ( void )
{
1995-05-20 00:13:14 +00:00
if ( ! mediaDevice ) {
msgConfirm ( " Media type not set! Please select a media type \n from the Installation menu before proceeding. " ) ;
1995-05-17 14:40:00 +00:00
return FALSE ;
}
1995-05-16 11:37:27 +00:00
return TRUE ;
}
1995-05-20 03:49:10 +00:00
void
mediaClose ( void )
{
}