summaryrefslogtreecommitdiffstats
path: root/doc_example/spreadsheet_doc_1.cpp
blob: 00bbba433d7178a38ccfc5f7da8bc9ea5f2e5d0e (plain)
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
#include <orcus/spreadsheet/document.hpp>
#include <orcus/spreadsheet/factory.hpp>
#include <orcus/orcus_ods.hpp>

#include <ixion/address.hpp>
#include <ixion/model_context.hpp>

#include <iostream>
#include <cstdlib>
#include <filesystem>

using namespace orcus;

int main()
{
    std::filesystem::path input_dir = std::getenv("INPUTDIR");

    //!code-start: instantiate
    spreadsheet::range_size_t ss{1048576, 16384};
    spreadsheet::document doc{ss};
    spreadsheet::import_factory factory{doc};
    //!code-end: instantiate

    //!code-start: loader
    orcus_ods loader(&factory);
    //!code-end: loader

    //!code-start: read-file
    auto filepath = input_dir / "document.ods";
    loader.read_file(filepath.native());
    //!code-end: read-file

    //!code-start: model-context
    const ixion::model_context& model = doc.get_model_context();
    //!code-end: model-context

    //!code-start: string-id
    ixion::abs_address_t pos(0, 0, 0); // Set the cell position to A1.
    ixion::string_id_t str_id = model.get_string_identifier(pos);
    //!code-end: string-id

    //!code-start: print-string
    const std::string* s = model.get_string(str_id);
    assert(s);
    std::cout << "A1: " << *s << std::endl;
    //!code-end: print-string

    //!code-start: rest
    pos.column = 1; // Move to B1
    str_id = model.get_string_identifier(pos);
    s = model.get_string(str_id);
    assert(s);
    std::cout << "B1: " << *s << std::endl;

    pos.column = 2; // Move to C1
    str_id = model.get_string_identifier(pos);
    s = model.get_string(str_id);
    assert(s);
    std::cout << "C1: " << *s << std::endl;
    //!code-end: rest

    return EXIT_SUCCESS;
}