123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491 |
- /******************************************************************************
- |* THIS CODE AND INFORMATION IS PROVIDED "AS IS" WITHOUT WARRANTY OF
- |* ANY KIND, EITHER EXPRESSED OR IMPLIED, INCLUDING BUT NOT LIMITED TO
- |* THE IMPLIED WARRANTIES OF MERCHANTABILITY AND/OR FITNESS FOR A
- |* PARTICULAR PURPOSE.
- |*
- |* Copyright 1995-2005 Nero AG. All Rights Reserved.
- |*-----------------------------------------------------------------------------
- |* NeroSDK / NeroAPI
- |*
- |* PROGRAM: NeroUserDialog.h
- |*
- |* PURPOSE: Ask how to proceed by offering the user some choices
- ******************************************************************************/
- #ifndef __NEROUSERDIALOG__
- #define __NEROUSERDIALOG__
- #if defined(__BORLANDC__)
- // NEROAPI expects structs to be 8byte aligned
- #pragma pack(push, 8)
- // tell Borland C++ Builder to treat enums as int
- #pragma option push -b
- #endif
- // Take care to use 2^n as values for constants:
- #define AUP_NO_PROBLEM 0 // No problems found
- #define AUP_FIRST_TR_PAUSE 1 // First track must have 2-3 secs pause!
- #define AUP_PAUSE_SETTINGS 2 // Problem with audio pause settings (tracks > 1)
- #define AUP_INDEX_SETTINGS 4 // Problem with audio index settings
- #define AUP_ISRC_SETTINGS 8 // Problem with ISRC settings
- #define AUP_COPYPROT_SETTINGS 16 // Problem with copyright settings
- #define AUP_NOTRACK_FOUND 32 // Problem because we don´t have any track
- #define AUP_MEGA_FATAL 0xFFFFFFFF // Megafatal internal problem that can´t be fixed!
- typedef enum NeroUserDlgInOutEnum {
- /* return codes for DLG_MESSAGEBOX: */
- DLG_RETURN_OK = -8, /* NeroAPI >= 6.0.0.6: ok */
- DLG_RETURN_YES = -7, /* NeroAPI >= 6.0.0.6: yes */
- DLG_RETURN_RETRY = -6, /* NeroAPI >= 6.0.0.6: retry */
- DLG_RETURN_IGNORE = -5, /* NeroAPI >= 6.0.0.6: ignore */
- DLG_RETURN_NO = -4, /* NeroAPI >= 6.0.0.6: no */
- DLG_RETURN_CANCEL = -3, /* NeroAPI >= 6.0.0.6: cancel */
- DLG_RETURN_ABORT = -2, /* NeroAPI >= 6.0.0.6: abort */
- /* NeroAPI >= 6.0.0.6:
- * return this if an enum is not handled by the callback
- */
- DLG_RETURN_NOT_HANDLED = -1,
- /* return codes for other dialogs */
- DLG_RETURN_EXIT = 0, /* Exit application / stop writing */
- DLG_RETURN_FALSE = 0, /* false */
- DLG_RETURN_TRUE = 1, /* true */
- /*
- "Disconnect is turned off in the system configuration.
- This may cause serious problems while burning: your CD might
- be damaged, or the system might hang up."
- */
- DLG_DISCONNECT = 2,
- DLG_RETURN_ON_RESTART = 3, /* turn on disconnect and restart windows */
- DLG_RETURN_RESTART = 4, /* Don't change disconnect option and restart windows */
- DLG_RETURN_CONTINUE = 5, /* Continue at your own risk */
- /* DLG_RETURN_EXIT */
- /* same as DLG_DISCONNECT, but restarting has been selected
- already and must not be canceled, so valid return codes
- are only DLG_RETURN_ON_RESTART and DLG_RETURN_RESTART */
- DLG_DISCONNECT_RESTART = 6,
- /*
- "Auto Insert Notification is turned on in the system configuration.
- This may cause serious problems while burning: your CD might be damaged,
- or the system might hang up.
- Nero is able to burn CDs with Auto Insert Notification turned on if all
- necessary drivers are installed."
- */
- DLG_AUTO_INSERT = 7,
- DLG_RETURN_INSTALL_DRIVER = 8, /* Install IO driver which temporarily disables auto insert. */
- /* Note: this only works if the additional argument for the callback is not NULL,
- otherwise it should not be offered to the user. */
- DLG_RETURN_OFF_RESTART = 9, /* Change autoinsert and restart Windows */
- /*
- as above:
- DLG_RETURN_EXIT,
- DLG_RETURN_CONTINUE,
- */
- /*
- "Please restart Windows now."
- */
- DLG_RESTART = 10,
- /* return code irrelevant */
- /*
- "Auto Insert Notification is now OFF. You should restart Windows."
- (displayed after rebooting within program failed and user has to do it manually)
- */
- DLG_AUTO_INSERT_RESTART = 11,
- /* return code irrelevant */
- /*
- "Nero detected some modifications of your PC system configuration
- and needs to modify some settings. Please restart your PC to make
- the changes become effective."
- */
- DLG_SETTINGS_RESTART = 12,
- /*
- DLG_RETURN_RESTART,
- DLG_RETURN_CONTINUE,
- */
- /*
- "Sorry, this compilation contains too much data to fit on the CD"
- with respect to the normal CD capacity. Do you want to try
- overburn writing at your own risk (this might cause read
- errors at the end of the CD or might even damage your recorder)?"
- "Note: It is also possible, that SCSI/Atapi errors occur at the end
- of the simulation or burning. Even in this case there is a certain
- chance, that the CD is readable."
- NeroAPI >= 6.0.0.27: the data parameter is a pointer to struct DLG_OVERBURN_INFO
- defined below.
- */
- DLG_OVERBURN = 13,
- /*
- DLG_RETURN_TRUE/FALSE
- */
- /*
- The tracks cannot be written as requested. A detailed
- description of the problem is found in the "data" parameter.
- It is a DWORD of with bits set according to the AUP constants above
- */
- DLG_AUDIO_PROBLEMS = 14,
- /*
- DLG_RETURN_TRUE = fix the problems by adapting the track settings
- DLG_RETURN_FALSE = stop writing
- */
- /*
- This dialog type differs slightly from the other ones:
- it should pop up a message and return immediately while still showing
- the message, so that the API can test for the expected CD in the meantime.
- During this time, the NERO_IDLE_CALLBACK will be called to give the
- application a chance to update its display and to test for user abort.
- The API might call call DLG_WAITCD several times to change the text.
- The text depends on the "data" argument that is passed to the
- NERO_USER_DIALOG callback. It is the enumeration NERO_WAITCD_TYPE
- specified below.
- */
- DLG_WAITCD = 15,
- /*
- It is time to remind the user of inserting the CD: play a jingle, flash the screen, etc.
- Called only once after a certain amount of time of no CD being inserted.
- */
- DLG_WAITCD_REMINDER = 16,
- /*
- Close the message box again, we are done.
- */
- DLG_WAITCD_DONE = 17,
- /*
- Tell the user that there will be quality loss during the copy and ask if he wants
- to continue anyway
- */
- DLG_COPY_QUALITY_LOSS = 18,
- /*
- PROCEED AT YOUR OWN RISK message
- */
- DLG_COPY_FULLRISK = 19,
- /*
- Ask the user the path of the file which will be generated by the Image Recorder.
- The "data" argument points on a MAX_PATH or PATH_MAX (depending on your OS) bytes buffer that has to be filled with the image path
- Returning DLG_RETURN_EXIT will stop the burn process
- */
- DLG_FILESEL_IMAGE = 20,
- /*
- Tell that there is not enough space on disk to produce this image
- */
- DLG_BURNIMAGE_CANCEL = 21,
- /*
- Tell the user that the CDRW is not empty
- Starting from NeroAPI 5.5.3.0, the "data" argument contains the device handle from the recorder
- Will be called only if the NBF_DETECT_NON_EMPTY_CDRW flags is given to the NeroBurn function
- Returning DLG_RETURN_EXIT will stop the burn process
- Returning DLG_RETURN_CONTINUE will continue the burn process
- Returning DLG_RETURN_RESTART will ask the user for an other CD
- */
- DLG_NON_EMPTY_CDRW = 22,
- /*
- NeroAPI 5.5.3.2: tell the user that the compilation cannot be written on that particular
- recorder and that the user shoud modify his compilation settings or burn the CD on
- another recorder, that supports the required medium type
- */
- DLG_COMP_REC_CONFLICT = 23,
- /*
- NeroAPI 5.5.3.2: another type of medium must be used to burn this compilation
- */
- DLG_WRONG_MEDIUM = 24,
- /* Implementation of the DLG_ROBO_MOVECD dialog types must behave
- * like the DLG_WAITCD type, that is, operate in a non-blocking way.
- * The data structure passed to this callback is specified as
- * ROBOMOVEMESSAGE below */
- DLG_ROBO_MOVECD = 25,
- /* Destroy a MoveCD dialog. (void*)data cast to an int will contain the
- * id of the MoveCD dialog to be removed */
- DLG_ROBO_MOVECD_DONE = 26,
- /* Show dialog message transmitted by the Robo driver.
- * Must return one of the constants below.
- * The data structure passed as the data pointer is specified as
- * ROBOUSERMESSAGE below.
- * Return DLG_RETURN_FALSE or DLG_RETURN_TRUE here */
- DLG_ROBO_USERMESSAGE = 27,
- /* Provide informations about which media is expected and which media is
- * currently present in the recorder.
- The data pointer passed is a pointer on the NERO_DLG_WAITCD_MEDIA_INFO structure
- declared in NeroAPI.h.
- The value returned is ignored*/
- DLG_WAITCD_MEDIA_INFO = 28,
- /* NeroAPI >= 6.0.0.6:
- * Open a custom messagebox dialog. The type and the message of the dialog are described
- * with a struct NERODLG_MESSAGEBOX which is given as data pointer.
- * See comments for NERODLG_MESSAGE_TYPE which values to return.
- */
- DLG_MESSAGEBOX = 29,
- /* NeroAPI >= 6.3.1.9:
- * "There is not enough free space in the temporary directory.
- * Please choose another one."
- * The data parameter is a pointer to struct DLG_TEMPSPACE_INFO defined below.
- */
- DLG_TEMPSPACE = 30,
- DLG_MAX
- } NeroUserDlgInOut;
- /* NeroAPI >= 6.0.0.6 */
- typedef enum
- {
- NDIT_INFO = 0, /* an info icon */
- NDIT_WARNING = 1, /* a warning icon */
- NDIT_ERROR = 2, /* an error icon */
- NDIT_QUESTION =3 /* a question icon */
- } NERODLG_ICON_TYPE;
- /* NeroAPI >= 6.0.0.6 */
- typedef enum
- {
- /* An info dialog with only an OK button. The return value is ignored.
- */
- NDMT_OK = 0,
- /* A dialog with a yes and a no button. Return DLG_RETURN_YES for Yes
- * and DLG_RETURN_NO for No.
- */
- NDMT_YESNO = 1,
- /* A dialog with a ok and a cancel button. Return DLG_RETURN_OK for OK
- * and DLG_RETURN_CANCEL for Cancel.
- */
- NDMT_OKCANCEL = 2,
-
- /* A dialog with a retry and a cancel button. Return DLG_RETURN_RETRY
- * for Retry and DLG_RETURN_CANCEL for Cancel.
- */
- NDMT_RETRYCANCEL = 3,
- /* A dialog with a abort, a retry and a ignore button.
- * Return DLG_RETURN_IGNORE for Ignore, DLG_RETURN_RETRY for Retry
- * and DLG_RETURN_ABORT for Abort.
- */
- NDMT_ABORTRETRYIGNORE = 4,
- /* A dialog with a yes, a no and a cancel button.
- * Return DLG_RETURN_YES for Yes, DLG_RETURN_NO for No
- * and DLG_RETURN_CANCEL for Cancel.
- */
- NDMT_YESNOCANCEL = 5
- } NERODLG_MESSAGE_TYPE;
- /* NeroAPI >= 6.0.0.6 */
- typedef struct
- {
- NERODLG_MESSAGE_TYPE type; /* the type of the message, see DLG_MESSAGE_TYPE */
- NERODLG_ICON_TYPE icon; /* the icon for the message, see DLG_ICON_TYPE */
- NeroUserDlgInOut defaultReturn; /* the default return value */
- const char* message; /* the message to display */
- } NERODLG_MESSAGEBOX;
- typedef enum
- {
- RUMT_ERROR,
- RUMT_WARNING,
- RUMT_QUESTION,
- RUMT_HINT
- } ROBOUSERMESSAGETYPE;
- typedef struct
- {
- ROBOUSERMESSAGETYPE message_type; // The type of message, see constants above */
- const char *message;
- } ROBOUSERMESSAGE;
- typedef enum
- {
- RMN_INPUT,
- RMN_RECORDER,
- RMN_OUTPUT,
- RMN_PRINTER,
- RMN_WASTEBIN
- } ROBOMOVENODE;
- typedef struct
- {
- int id; /* In future versions, we may have more than one Robo moving
- * at a time. So this ID identifies the movement action
- * and will be used to remove it with DLG_ROBO_MOVECD_DONE */
- ROBOMOVENODE source;
- ROBOMOVENODE destination;
- } ROBOMOVEMESSAGE;
- /* NeroAPI >= 6.0.0.27: Additional information when DLG_OVERBURN is called */
- typedef struct
- {
- DWORD dwTotalBlocksOnCD; /* total blocks to be written to disc */
- DWORD dwTotalCapacity; /* free capacity on disc in blocks */
- DWORD reserved[32]; /* reserved for future usage */
- } DLG_OVERBURN_INFO;
- typedef struct
- {
- const char* pCurrentDir;
- __int64 i64FreeSpace; /* free space on the disc in bytes */
- __int64 i64SpaceNeeded; /* space needed in bytes */
- char* pNewTempDir; /* a buffer of size iNewTempDirLength where you can
- * copy the path to the new temporary directory */
- int iNewTempDirLength; /* The size of the pNewTempDirBuffer */
- DWORD reserved[32]; /* reserved for future usage */
- } DLG_TEMPSPACE_INFO;
- /*
- // This function gets a requester type and shall return a suitable response to it.
- // Depending on the "type", "data" might contain additional information.
- //
- // Argument passing is in standard C order (on the stack, right to left),
- // aka MS Visual++ __cdecl.
- */
- /* Define __cdecl for non-Microsoft compilers */
- #if ( !defined(_MSC_VER) && !defined(__cdecl) )
- #define __cdecl
- #endif
- #define NERO_CALLBACK_ATTR __cdecl
- typedef NeroUserDlgInOut (NERO_CALLBACK_ATTR *NERO_USER_DIALOG) (void *pUserData, NeroUserDlgInOut type, void *data);
- /*
- // see below for a description of the enumeration values
- */
- typedef enum
- {
- NERO_WAITCD_WRITE,
- NERO_WAITCD_SIMULATION,
- NERO_WAITCD_AUTOEJECTLOAD,
- NERO_WAITCD_REINSERT,
- NERO_WAITCD_NEXTCD,
- NERO_WAITCD_ORIGINAL,
- NERO_WAITCD_WRITEPROTECTED,
- NERO_WAITCD_NOTENOUGHSPACE,
- NERO_WAITCD_NEWORIGINAL,
- NERO_WAITCD_EMPTYCD,
- NERO_WAITCD_WRITE_EMPTY,
- NERO_WAITCD_SIMULATION_EMPTY,
- NERO_WAITCD_WRITEWAVE,
- NERO_WAITCD_MULTISESSION,
- NERO_WAITCD_MULTISESSION_SIM,
- NERO_WAITCD_MULTI_REINSERT,
- NERO_WAITCD_DISCINFOS_FAILED,
- NERO_WAITCD_MEDIUM_UNSUPPORTED,
- NERO_WAITCD_AUTOEJECTLOAD_VER,
- NERO_WAITCD_REINSERT_VER,
- NERO_WAITCD_NOFORMAT,
- NERO_WAITCD_WRONG_MEDIUM, // NeroAPI>=5.5.5.6
- NERO_WAITCD_WAITING, // NeroAPI>=5.5.10.26
- NERO_WAITCD_EMPTYCDRW, // NeroAPI>=6.0.0.20
- NERO_WAITCD_NOTENOUGHSPACERW, // NeroAPI>=6.0.0.20
- NERO_WAITCD_NOTENOUGHSPACE_80MIN,
- NERO_WAITCD_MAX
- } NERO_WAITCD_TYPE;
- #endif /* __NEROUSERDIALOG__ */
- #ifdef NERO_WAITCD_TEXTS /* define this in exactly one source file before including NeroUserDialog.h there. */
- #include <assert.h>
- #ifndef NERO_WAITCD_TEXTS_DEFINED
- #define NERO_WAITCD_TEXTS_DEFINED
- /* If NeroAPI>=5.5.9.10 is present, it is recommanded to use NeroGetLocalizedWaitCDTexts instead since it
- returns a localized string */
- static const char *NeroGetWaitCDTexts (NERO_WAITCD_TYPE type)
- {
- static struct
- {
- NERO_WAITCD_TYPE type;
- const char *text;
- } mapping[] =
- {
- { NERO_WAITCD_WRITE, "Please insert the disc to write to..." },
- { NERO_WAITCD_SIMULATION, "Please insert a disc to use during simulation...\n\n(Nothing will be written on the disc.)" },
- { NERO_WAITCD_AUTOEJECTLOAD,
- "Please do not remove the disc!\n\nYour recorder requires this eject between simulation and burning. The disc will be reloaded automatically before continuing with burning..." },
- { NERO_WAITCD_REINSERT, "Please do not remove the disc!\n\nYour recorder requires this eject between simulation and burning. Please reinsert the disc..." },
- { NERO_WAITCD_NEXTCD, "Please remove the disc and insert the next recordable disc to write to... " },
- { NERO_WAITCD_ORIGINAL, "Please insert the original disc." },
- { NERO_WAITCD_WRITEPROTECTED,
- "This disc is not writable.\n\nPlease insert a writable disc..." },
- { NERO_WAITCD_NOTENOUGHSPACE,
- "There is not enough space to burn this compilation onto this disc.\n\nPlease insert another disc that provides more space..." },
- { NERO_WAITCD_NEWORIGINAL, "The disc is blank, invalid\nor a multisession disc.\n\nPlease insert original disc ..." },
- { NERO_WAITCD_EMPTYCD, "The disc is not empty.\n\nPlease insert an empty disc." },
- { NERO_WAITCD_WRITE_EMPTY, "Please insert an empty disc to write to..." },
- { NERO_WAITCD_SIMULATION_EMPTY,
- "Please insert an empty disc to use during simulation...\n\n(Nothing will be written on the disc.)" },
- { NERO_WAITCD_WRITEWAVE, "The disc is blank.\n\nPlease insert original disc..." },
- { NERO_WAITCD_MULTISESSION, "Nero is checking for the disc, please wait ...\n\nTo burn this multisession compilation you need the disc, that contains the previous backup sessions. Please insert this disc if you haven't done it before." },
- { NERO_WAITCD_MULTISESSION_SIM,
- "To simulate this multisession compilation you need the disc, that contains the previous backup sessions. Please insert this disc. (Nothing will be written on disc)." },
- { NERO_WAITCD_MULTI_REINSERT,
- "Please do not remove the disc!\n\nYour recorder requires this eject between simulation and burning. Please reinsert the\n same Multisession disc..." },
- { NERO_WAITCD_DISCINFOS_FAILED,
- "Disc analysis failed. The error log\ncontains more information about the reason."},
- { NERO_WAITCD_MEDIUM_UNSUPPORTED,
- "The recorder does not support this type of media!\n\nPlease insert a correct disc to write to..."},
- { NERO_WAITCD_AUTOEJECTLOAD_VER, "Please do not remove the disc!\n\nYour recorder requires that the disc be ejected between burning and verification. The disc will be reloaded automatically when burning is to continue..." },
- { NERO_WAITCD_REINSERT_VER, "Please do not remove the disc!\n\nYour recorder requires that the disc be ejected between burning and verification. Please reinsert the disc...." },
- { NERO_WAITCD_NOFORMAT, "The disc is not formatted. Please insert a formatted disc." },
- { NERO_WAITCD_WRONG_MEDIUM, "Sorry, your compilation cannot be written on this kind of disc. Please insert a disc of the correct type or modify the settings of your compilation to make them compatible with the current disc." },
- { NERO_WAITCD_WAITING, "--- Accessing disc, please wait ---"},
- { NERO_WAITCD_EMPTYCDRW, "The disc is not empty." },
- { NERO_WAITCD_NOTENOUGHSPACERW, "There is not enough space to burn the compilation onto this disc."},
- { NERO_WAITCD_NOTENOUGHSPACE_80MIN, "There is not enough space to burn the compilation onto this disc.\n\nPlease insert a 80min/700MB media"},
- { NERO_WAITCD_MAX, "unknown NERO_WAITCD_TYPE" }
- };
- int i;
- /*
- * Please use NeroGetLocalizedWaitCDTexts instead of NeroGetWaitCDTexts.
- * NeroGetLocalizedWaitCDTexts gets the strings from the message file and therefore
- * always returns the correct string also if a new NERO_WAITCD_TYPE has been added
- * to NeroAPI.
- */
- assert(!"NeroGetWaitCDTexts is deprecated.");
- for (i = 0; mapping[i].type != type && mapping[i].type != NERO_WAITCD_MAX; i++)
- ;
- assert (mapping[i].type != NERO_WAITCD_MAX);
- return mapping[i].text;
- }
- #endif
- #if defined(__BORLANDC__)
- #pragma pack(pop)
- #pragma option pop
- #endif
- #endif
|