~thomas-voss/location-service/fix-1347887

« back to all changes in this revision

Viewing changes to include/location_service/com/ubuntu/location/service/stub.h

This MP consolidates multiple related changes together, with the goal of:

(1.) Make the service instance accessible via a cli. Useful for testing scenarios.
(2.) To cut down time-to-first-fix (ttff) by:
  (2.1) Leveraging SUPL and other supplementary data downloaded over ordinary data connections.
  (2.2) Enabling network-based positioning providers to acquire fast position estimates.

In more detail:

* Added tests for daemon and cli.
* Unified daemon and cli header and implementation files.
* Add a command-line interface to the service.
* Split up provider selection policy to rely on an interface ProviderEnumerator to ease in testing.
* Trimmed down on types.
* Removed connectivity API draft to prepare for simpler approach.
* Refactored includes.
* Added a configuration option to handle cell and wifi ID reporting.
* Add a mock for a connectivity API exposed to providers and reporters.
* Add units for connectivity api.
* Refactor cell class into namespace radio. Fixes: 1226204, 1248973, 1281817

Show diffs side-by-side

added added

removed removed

Lines of Context:
18
18
#ifndef LOCATION_SERVICE_COM_UBUNTU_LOCATION_SERVICE_STUB_H_
19
19
#define LOCATION_SERVICE_COM_UBUNTU_LOCATION_SERVICE_STUB_H_
20
20
 
21
 
#include "com/ubuntu/location/service/interface.h"
22
 
#include "com/ubuntu/location/service/session/interface.h"
 
21
#include <com/ubuntu/location/service/interface.h>
 
22
#include <com/ubuntu/location/service/session/interface.h>
23
23
 
24
24
#include <core/dbus/stub.h>
25
25
 
40
40
    ~Stub() noexcept;
41
41
 
42
42
    session::Interface::Ptr create_session_for_criteria(const Criteria& criteria);
 
43
    core::Property<bool>& does_satellite_based_positioning();
 
44
    core::Property<bool>& does_report_cell_and_wifi_ids();
 
45
    core::Property<bool>& is_online();    
 
46
    core::Property<std::map<SpaceVehicle::Key, SpaceVehicle>>& visible_space_vehicles();
43
47
 
44
48
  private:
45
49
    struct Private;