vfs: check userland buffers before reading them.
[haiku.git] / docs / user / app / Application.dox
blob56d9bc011224b5480387f282835539e438ecc324
1 /*
2  * Copyright 2011-2014 Haiku, Inc. All rights reserved.
3  * Distributed under the terms of the MIT License.
4  *
5  * Authors:
6  *              John Scipione, jscipione@gmail.com
7  * 
8  * Corresponds to:
9  *              headers/os/app/Application.h    hrev47355
10  *              src/kits/app/Application.cpp    hrev47355
11  */
14 /*!
15         \file Application.h
16         \ingroup app
17         \ingroup libbe
18         \brief Provides the BApplication class.
22 /*!
23         \var be_app
24         \brief Global system app object.
26         \since BeOS R3
30 /*!
31         \var be_app_messenger
32         \brief Global system app messenger object.
34         \since BeOS R3
38 /*!
39         \class BApplication
40         \ingroup app
41         \ingroup libbe
42         \brief A container object for an application.
44         A BApplication establishes a connection between the application and the
45         Application Server.
47         The most common task performed by a BApplication object is to handle
48         messages sent to it. The BApplication object also is used
49         to get information about your application such as the number of windows
50         it has, its signature, executable location, and launch flags.
52         The BApplication object is automatically assigned to the global \c be_app
53         variable. The \c be_app variable allows you to refer to your BApplication
54         object from anywhere in the code.
56         To use a BApplication you first construct the object and then begin its
57         message loop by calling the Run() method. The Run() method
58         continues until the application is told to quit. Once Run() returns you
59         should then delete the BApplication object to free its memory usage.
61         Typically, you initialize the BApplication object in the programs main()
62         function. A typical main() function looks something like this:
64 \code
65 #include Application.h
67 main()
69         /* Vendor is your vendor name, application is your application name */
70         BApplication app("application/x-vnd.vendor-application");
71         app->Run();
72         delete app;
74         return 0;
76 \endcode
78         \since BeOS R3
82 /*!
83         \fn BApplication::BApplication(const char* signature)
84         \brief Initialize a BApplication with the passed in \a signature.
86         The new BApplication is, by default, not running yet. If you have
87         everything set up properly call Run() to start the application.
89         You should call InitCheck() to check for constructor initialization
90         errors.
92         \param signature The \a signature of the application.
94         \since BeOS R3
98 /*!
99         \fn BApplication::BApplication(const char* signature, status_t* _error)
100         \brief Initialize a BApplication with the passed in \a signature and a
101                pointer to an error message.
103         Any error that occurs while constructing the BApplication will be
104         set to the \a _error pointer. If \a _error points to a \c status_t
105         error then you should not call Run().
107         Alternately, you can call InitCheck() to check for constructor 
108         initialization errors.
110         \param signature The \a signature of the application.
111         \param _error A pointer to a \c status_t set by the BApplication
112                 constructor.
114         \since BeOS R5
118         \fn status_t BApplication::InitCheck() const
119         \brief Returns the status of the constructor.
121         \returns If initialization succeeded returns \c B_OK, otherwise returns an
122                  error status.
124         \since BeOS R5
129         \name Archiving
133 //! @{
137         \fn BApplication::BApplication(BMessage* data)
138         \brief Initialize a BApplication object from a message.
140         The message must contain the signature of the application you wish to
141         initialize in the "mime_sig" variable.
143         \param data The message to initialize the BApplication from.
145         \since BeOS R3
150         \fn status_t BApplication::Archive(BMessage* data, bool deep) const
151         \brief Archive the BApplication object into a BMessage.
153         \sa BArchivable::Archive()
155         \since BeOS R3
160         \fn BArchivable* BApplication::Instantiate(BMessage* data)
161         \brief Restores the BApplication object from a BMessage.
163         \sa BArchivable::Instantiate()
165         \since BeOS R3
169 //! @}
173         \fn BApplication::~BApplication()
174         \brief Destructor Method
176         \since BeOS R3
181         \name Message Loop Control
185 //! @{
189         \fn thread_id BApplication::Run()
190         \brief Starts the message loop in the thread that it is called from,
191                and doesn't return until the message loop stops.
193         Run() does not spawn a new thread.
195         \return The thread_id of the thread that the BApplication is called from.
197         \since BeOS R3
202         \fn void BApplication::Quit()
203         \brief Tells the thread to finish processing the message queue, disallowing
204                any new messages.
206         Quit() doesn't kill the looper thread. After Quit() returns, it doesn't wait
207         for the message queue to empty. Run() will be then able to return. 
209         Quit() doesn't delete the BApplication object after Run() is called. You
210         should delete the BApplication object yourself one Run() returns.
211         However Quit() does delete the object if it's called before the message loop
212         starts i.e. before Run() is called.
214         \since BeOS R3
218 //! @}
222         \name Hook Methods
226 //! @{
230         \fn bool BApplication::QuitRequested()
231         \brief Hook method that gets invoked when the BApplication receives a
232                \c B_QUIT_REQUESTED message.
234         BApplication sends a QuitRequested() message to each of its BWindow objects.
235         If all of the BWindow s return \c true then the windows are
236         each destroyed (through BWindow::Quit()) and QuitRequested() returns
237         \c true. If any of the BWindow returns \c false, the BWindow s
238         are not destroyed and QuitRequested() returns \c false.
240         \return \c true if the application quit or \c false if the
241                 application failed to quit.
243         \since BeOS R3
248         \fn void BApplication::ReadyToRun()
249         \brief Hook method that's invoked when the BApplication receives a
250                \c B_READY_TO_RUN message.
252         The ReadyToRun() method is automatically called by the Run() method. It is
253         sent after the initial \c B_REFS_RECEIVED and \c B_ARGV_RECEIVED messages
254         (if any) have already been handled. ReadyToRun() is the only message that
255         every running application is guaranteed to receive.
257         The default version of ReadyToRun() is empty. You should override the
258         ReadyToRun() method to do whatever you want to do. If you haven't
259         constructed any windows in your application yet then this would be a good
260         place to do so.
262         \since BeOS R3
267         \fn void BApplication::ArgvReceived(int32 argc, char** argv)
268         \brief Hook method that gets invoked when the application receives a
269                \c B_ARGV_RECEIVED message.
271         If command line arguments are specified when the application is launched
272         from the the shell, or if \c argv/argc values are passed to
273         BRoster::Launch(), then this method is executed.
275         \warning ArgvReceived() is not called if no command line arguments are
276         specified, or if BRoster::Launch() was called without any \c argv/argc
277         values.
279         The arguments passed to ArgvReceived() are the constructed in the same way
280         as those passed to command line programs. The number of command line
281         arguments is passed in \a argc and the arguments themselves are passed as an
282         array of strings in \a argv. The first \a argv string is the name of the
283         program and the rest of the strings are the command line arguments.
285         BRoster::Launch() adds the program name to the front of the \a argv array
286         and increments the \a argc value.
288         The \c B_ARGV_RECEIVED message (if sent) is sent only once, just
289         before the \c B_READY_TO_RUN message is sent. However, if you try to
290         relaunch an application that is already running and the application is set
291         to \c B_EXCLUSIVE_LAUNCH or \c B_SINGLE_LAUNCH then the application will
292         generate a \c B_ARGV_RECEIVED message and send it to the already running
293         instance. Thus in this case the \c B_ARGV_RECEIVED message can show
294         up at any time.
296         \since BeOS R3
301         \fn void BApplication::AppActivated(bool active)
302         \brief Hook method that gets invoked when the application receives
303         \c B_APP_ACTIVATED message.
305         The message is sent whenever the application changes its active application
306         status. The active flag set to is \c true when the application becomes
307         active and is set to \c false when the application becomes inactive.
309         The application becomes activated in response to a user action such as
310         clicking on or unhiding one of its windows. The application can have its
311         active status set programmatically by calling either the BWindow::Activate()
312         or BRoster::ActivateApp() methods.
314         This method is called after ReadyToRun() provided the application is
315         displaying a window that can be set active.
317         \since BeOS R3
322         \fn void BApplication::RefsReceived(BMessage* message)
323         \brief Hook method that gets invoked when the application receives a
324                \c B_REFS_RECEIVED message.
326         The message is sent in response to a user action such as a user
327         drag-and-dropping a file on your app's icon or opening a file that the
328         application is set to handle. You can use the IsLaunching() method to
329         discern whether the message arrived when the application is launched or
330         after the application has already been running.
332         The default implementation is empty. You can override this method to do
333         something with the received refs. Typically you create BEntry or BFile
334         objects from the passed in refs.
336         \param message contains a single field named "be:refs" that contains one
337                or more entry_ref (\c B_REF_TYPE) items, one for each file sent.
339         \since BeOS R3
344         \fn void BApplication::AboutRequested()
345         \brief Hook method that gets invoked when the BApplication receives a
346                \c B_ABOUT_REQUESTED message.
348         You should override this method to pop an alert to provide information
349         about the application.
351         The default implementation pops a basic alert dialog.
353         \since BeOS R3
357 //! @}
361         \name Cursor
365 //! @{
369         \fn BApplication::ShowCursor()
370         \brief Restores the cursor.
372         \since BeOS R3
377         \fn void BApplication::HideCursor()
378         \brief Hides the cursor from the screen.
380         \since BeOS R3
385         \fn void BApplication::ObscureCursor()
386         \brief Hides the cursor until the mouse is moved.
388         \since BeOS R3
393         \fn bool BApplication::IsCursorHidden() const
394         \brief Returns whether or not the cursor is hidden.
396         \returns \c true if the cursor is hidden, \c false if not.
398         \since BeOS R3
403         \fn void BApplication::SetCursor(const void* cursor)
404         \brief Sets the \a cursor to be used when the application is active.
406         You can pass one of the pre-defined cursor constants such as
407         \c B_HAND_CURSOR or \c B_I_BEAM_CURSOR or you can create your own pass
408         in your own cursor image. The cursor data format is described in the BCursor
409         class.
411         \param cursor The cursor data to set the cursor to.
413         \since BeOS R3
418         \fn void BApplication::SetCursor(const BCursor* cursor, bool sync)
419         \brief Sets the \a cursor to be used when the application is active
420                with \a sync immediately option.
422         The default BCursors to use are \c B_CURSOR_SYSTEM_DEFAULT for the hand
423         cursor and \c B_CURSOR_I_BEAM for the I-beam cursor.
425         \param cursor A BCursor object to set the \a cursor to.
426         \param sync synchronize the cursor immediately.
428         \since BeOS R5
432 //! @}
436         \name Info
440 //! @{
444         \fn int32 BApplication::CountWindows() const
445         \brief Returns the number of windows created by the application.
447         \returns the number of windows created by the application.
449         \since BeOS R3
454         \fn BWindow* BApplication::WindowAt(int32 index) const
455         \brief Returns the BWindow object at the specified \a index in the
456                application's window list.
458         If \a index is out of range, this function returns \c NULL.
460         \warning Locking the BApplication object doesn't lock the window list.
462         \param index The \a index of the desired BWindow.
464         \returns The BWindow object at the specified \a index or \c NULL
465                  if the \a index is out of range.
467         \since BeOS R3
472         \fn int32 BApplication::CountLoopers() const
473         \brief Returns the number of BLoopers created by the application.
475         \warning This method may return \c B_ERROR.
477         \returns The number of BLoopers in the application.
479         \since BeOS R5
484         \fn BLooper* BApplication::LooperAt(int32 index) const
485         \brief Returns the BLooper object at the specified index in the
486                application's looper list.
488         If index is out of range, this function returns \c NULL.
490         \returns The BLooper object at the specified \a index or \c NULL
491                  if the \a index is out of range.
493         \since BeOS R5
497 //! @}
501         \name Status
505 //! @{
509         \fn bool BApplication::IsLaunching() const
510         \brief Returns whether or not the application is in the process of
511                launching.
513         \returns \c true if the application is launching, \c false if the
514                  application is already running.
516         \since BeOS R3
521         \fn status_t BApplication::GetAppInfo(app_info *info) const
522         \brief Fills out the \a info parameter with information about the
523                application.
525         This is equivalent to
526         be_roster->GetRunningAppInfo(be_app->Team(), info);
528         \returns \c B_NO_INIT on an error or \c B_OK if all goes well.
530         \sa BRoster::GetAppInfo()
532         \since BeOS R3
537         \fn BResources* BApplication::AppResources()
538         \brief Returns a BResources object for the application.
540         \since BeOS R5
544 //! @}
548         \name Message Mechanics
552 //! @{
556         \fn void BApplication::MessageReceived(BMessage *message)
557         \copydoc BHandler::MessageReceived()
562         \fn void BApplication::DispatchMessage(BMessage *message,
563                 BHandler *handler)
564         \copydoc BLooper::DispatchMessage()
568 //! @}
572         \name Pulse
576 //! @{
580         \fn void BApplication::Pulse()
581         \brief Hook method that gets invoked when the BApplication receives a
582                \c B_PULSE message.
584         An action is performed each time app_server calls the Pulse() method. 
585         The pulse rate is set by SetPulseRate(). You can implement Pulse() to do
586         anything you want. The default version does nothing. The pulse granularity
587         is no better than once per 100,000 microseconds.
589         \sa SetPulseRate()
591         \since BeOS R3
596         \fn void BApplication::SetPulseRate(bigtime_t rate)
597         \brief Sets the interval that the \c B_PULSE messages are sent.
599         If the \a rate is set to 0 then the \c B_PULSE messages are not sent.
600         The pulse rate can be no faster than once per 100,000 microseconds or so.
602         \param rate The rate at which \c B_PULSE messages are sent to the
603                application.
605         \since BeOS R3
609 //! @}
613         \name Scripting
617 //! @{
621         \fn BHandler* BApplication::ResolveSpecifier(BMessage* message,
622                 int32 index, BMessage *specifier, int32 what, const char *property)
623         \copydoc BHandler::ResolveSpecifier()
628         \fn status_t BApplication::GetSupportedSuites(BMessage* data)
629         \copydoc BHandler::GetSupportedSuites()
633 //! @}