FreeburnCommandDialog.h
上传用户:cnxinhai
上传日期:2013-08-06
资源大小:265k
文件大小:5k
- /* This is the class description for the Executing Command Output Dialog.
- *
- * Copyright (C) 2001, 2002 Adam Schlag
- */
- /*
- * FreeBurn Software License
- * (based on the Apache Software License)
- *
- * Version 1.1
- *
- * Copyright (c) 2001, 2002 The FreeBurn Project. 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.
- *
- * 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. The end-user documentation included with the redistribution, if any, must
- * include the following acknowledgment:
- *
- * "This product includes software developed by the FreeBurn
- * Project (http://freeburn.sourceforge.net/)."
- *
- * Alternately, this acknowledgment may appear in the software itself,
- * if and wherever such third-party acknowledgments normally appear.
- *
- * 4. The names "FreeBurn" and "FreeBurn Project" must not be
- * used to endorse or promote products derived from this software
- * without prior written permission. For written permission, please
- * contact aschlag@users.sourceforge.net.
- *
- * 5. Products derived from this software may not be called "FreeBurn",
- * nor may "FreeBurn" appear in their name, without prior written
- * permission of the FreeBurn Project.
- *
- * THIS SOFTWARE IS PROVIDED "AS IS" AND ANY EXPRESSED 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 THE FREEBURN PROJECT OR ITS
- * CONTRIBUTORS 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, 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.
- *
- * This software consists of voluntary contributions made by many
- * individuals on behalf of the FreeBurn Project. For more
- * information on the FreeBurn Project and FreeBurn, please see
- * <http://freeburn.sourceforge.net/>.
- *
- * This software is distributed with software that is released under the GNU
- * General Public License (GPL). You can find the terms of this license in the
- * file GPL.txt distributed in this package. You can find information on the
- * software distributed with this package in the file PROGRAMS.txt.
- */
- class CFreeburnCommandDialog : public FXDialogBox
- {
- FXDECLARE(CFreeburnCommandDialog)
-
- public:
- // The new message ID's used in the dialog
- enum{
- ID_SAVELOG=FXDialogBox::ID_LAST,
- ID_LOGTEXT,
- ID_LAST
- };
-
- // message handlers for hiding/showing the output log
- long saveOutputLog (FXObject*, FXSelector, void*);
- // the constructor and destructor we'll use
- CFreeburnCommandDialog(FXWindow* owner);
- virtual ~CFreeburnCommandDialog();
-
- // over-ride the Dialog execute so we can do some of our own stuff...
- //FXuint execute(FXuint placement);
-
- // method to set the save icon to use in the dialog
- void setSaveIcon(FXIcon* saveIcon);
-
- // methods for setting the text for the command string and output
- void setCommandLabelText(FXString& commandString);
- void sendOutputText (FXString& outputString);
-
- // method to run when output is complete
- void outputComplete();
- protected:
-
- private:
- // default constructors used by FOX
- CFreeburnCommandDialog(){}
- CFreeburnCommandDialog(const CFreeburnCommandDialog&);
-
- // label to show the command being executed
- FXLabel* m_CommandLabel;
-
- // label to show the current line of output
- FXLabel* m_OutputLabel;
-
- // text area to contain the entire contents of the output
- FXText* m_OutputText;
-
- // buttons for hiding and showing the output log window
- FXButton* m_ShowLogButton;
- FXButton* m_HideLogButton;
-
- // button for saving the output log to a text file
- FXButton* m_SaveLogButton;
-
- // OK button to close the dialog when complete.
- FXButton* m_OkButton;
- };
-