/usr/include/falcon/service.h is in falconpl-dev 0.9.6.9-git20120606-2.
This file is owned by root:root, with mode 0o644.
The actual contents of the file can be viewed below.
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 | /*
FALCON - The Falcon Programming Language.
FILE: service.h
Service declaration
-------------------------------------------------------------------
Author: Giancarlo Niccolai
Begin: lun feb 13 2006
-------------------------------------------------------------------
(C) Copyright 2004: the FALCON developers (see list in AUTHORS file)
See LICENSE file for licensing details.
*/
/** \file
Service and service provider classes.
*/
#ifndef flc_service_H
#define flc_service_H
#include <falcon/string.h>
namespace Falcon {
/** Service class.
Falcon modules are meant to interact with OS, databases, web servers, and many other
resources in behalf of Falcon scripts.
However, some of the resources handled by Falcon binary modules may be extremely
useful also for embedding application. Instead of re-linking or re-abstracting the required
low level services, this interface allows the modules to publish a set of functionalities
that can be used by both the Falcon scripts and the embedding application. This also
grants a somehow more direct interface between applications and scripts, that can share
objects representing low level resources as files, database connections, shared memory,
internet sockets and so on.
Service are required to a module by the Falcon::Module::getService(). a module
will publish its services via Falcon::Module::publishService(). Applications willing
to create many service instance in a row may find more efficient to use
Falcon::Module::getServiceProvider(), which returns a factory for the given service.
As Falcon modules are objects that should usually be loaded via DLL interface, a service will
declare all of its methods as virtual (except for const inline methdos), so that access to
methods by the user application won't require any linkage with the falcon modules. Of course,
this causes a minor inefficience in function calls.
The module where services are defined should declare
\code
#define FALCON_EXPORT_SERVICE
\endcode
before any Falcon file is inlcuded (specifically, before falcon/setup.h). This will tell
MS-Windows compilers that the module is willing to offer the service to the users of the target
DLL. Subclasses derived from services should maintain the FALCON_SERVICE signature to provide
the same DLL export policy (necessary in MSVC C++ projects).
\note Willing to spare every bit of CPU on module side for non-required overhead, the FALCON_FUNC
that interacts with the script may call directly the needed function as C calls, passing the
pointer to the service to them just as a data holder. The Service instance will hold the required
data plus the set of pointers to the functions that are to be published. Methods may then be
just inline calls to those function pointers; this will still require no linkage for modules into
applications, and will have the same speed as virtual method calls, but you'll spare extra
virtual calls inside the module.
*/
class FALCON_SERVICE Service {
String m_name;
public:
/** Creates the service assigning it a certain name.
The service requries a name by which it can be published by the module.
*/
Service( const String & name );
/** Destructor needs to be virtual. */
virtual ~Service();
const String &getServiceName() const { return m_name; }
};
}
#endif
/* end of service.h */
|