File: PathSettingsTest.cs

package info (click to toggle)
libreoffice 4%3A25.8.2-3
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid
  • size: 3,815,320 kB
  • sloc: cpp: 4,378,739; xml: 454,679; java: 257,215; python: 80,874; ansic: 33,824; perl: 30,304; javascript: 19,722; sh: 11,717; makefile: 10,622; cs: 8,865; yacc: 8,549; objc: 2,131; lex: 1,379; asm: 1,231; awk: 996; pascal: 914; csh: 20; sed: 5
file content (95 lines) | stat: -rw-r--r-- 3,307 bytes parent folder | download | duplicates (6)
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
88
89
90
91
92
93
94
95
/*
 * This file is part of the LibreOffice project.
 *
 * This Source Code Form is subject to the terms of the Mozilla Public
 * License, v. 2.0. If a copy of the MPL was not distributed with this
 * file, You can obtain one at http://mozilla.org/MPL/2.0/.
 */

using System;

using com.sun.star.beans;
using com.sun.star.lang;
using com.sun.star.uno;
using com.sun.star.util;

// List of pre-defined path variables supported by the PathSettings service
string[] predefinedPathProperties =
{
    "Addin", "AutoCorrect", "AutoText", "Backup", "Basic",
    "Bitmap", "Config", "Dictionary", "Favorite", "Filter",
    "Gallery", "Graphic", "Help", "Linguistic", "Module",
    "Palette", "Plugin", "Storage", "Temp", "Template",
    "UIConfig", "UserConfig", "UserDictionary", "Work"
};

// Provides an example for accessing and using the PathSettings service
try
{
    // Start a new office process and get the remote office context
    XComponentContext context = NativeBootstrap.bootstrap();
    Console.WriteLine("Connected to a running office...");

    XPropertySet pathSettings = thePathSettings.get(context);
    WorkWithPathSettings(pathSettings);

    return 0;
}
catch (Exception e)
{
    Console.Error.WriteLine(e);

    return 1;
}

// Retrieve and set path properties using the PathSettings service
void WorkWithPathSettings(XPropertySet pathSettings)
{
    if (pathSettings != null)
    {
        foreach (string prop in predefinedPathProperties)
        {
            try
            {
                string value = pathSettings.getPropertyValue(prop).cast<string>();
                Console.WriteLine($"Property = {prop} | Path = {value}");
            }
            catch (UnknownPropertyException)
            {
                Console.Error.WriteLine($"UnknownPropertyException was thrown while accessing {prop}");
            }
            catch (WrappedTargetException)
            {
                Console.Error.WriteLine($"WrappedTargetException was thrown while accessing {prop}");
            }
        }

        // Try to modify the work path property.
        // After running this example you should see the new value of "My Documents"
        // in the Paths tab, accessible via "Tools - Options - LibreOffice - Paths".
        // The change can be reverted through the Paths tab as well.
        try
        {
            pathSettings.setPropertyValue("Work", new Any("$(temp)"));
            string value = pathSettings.getPropertyValue("Work").cast<string>();
            Console.WriteLine("Note: The example changes your current work path setting!");
            Console.WriteLine($"The work path should now be {value}");
        }
        catch (UnknownPropertyException)
        {
            Console.Error.WriteLine("UnknownPropertyException was thrown while setting Work path");
        }
        catch (WrappedTargetException)
        {
            Console.Error.WriteLine("WrappedTargetException was thrown while setting Work path");
        }
        catch (PropertyVetoException)
        {
            Console.Error.WriteLine("PropertyVetoException was thrown while setting Work path");
        }
        catch (IllegalArgumentException)
        {
            Console.Error.WriteLine("IllegalArgumentException was thrown while setting Work path");
        }
    }
}