annotate Resources/Samples/OrthancCppClientStandalone/Basic/main.cpp @ 588:a0001c222b32

refactoring of samples
author Sebastien Jodogne <s.jodogne@gmail.com>
date Wed, 02 Oct 2013 15:00:18 +0200
parents 7f9467b5f33b
children
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
531
7f9467b5f33b samples
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
1 /**
7f9467b5f33b samples
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
2 * Orthanc - A Lightweight, RESTful DICOM Store
7f9467b5f33b samples
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
3 * Copyright (C) 2012-2013 Medical Physics Department, CHU of Liege,
7f9467b5f33b samples
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
4 * Belgium
7f9467b5f33b samples
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
5 *
7f9467b5f33b samples
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
6 * Permission is hereby granted, free of charge, to any person
7f9467b5f33b samples
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
7 * obtaining a copy of this software and associated documentation
7f9467b5f33b samples
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
8 * files (the "Software"), to deal in the Software without
7f9467b5f33b samples
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
9 * restriction, including without limitation the rights to use, copy,
7f9467b5f33b samples
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
10 * modify, merge, publish, distribute, sublicense, and/or sell copies
7f9467b5f33b samples
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
11 * of the Software, and to permit persons to whom the Software is
7f9467b5f33b samples
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
12 * furnished to do so, subject to the following conditions:
7f9467b5f33b samples
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
13 *
7f9467b5f33b samples
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
14 * The above copyright notice and this permission notice shall be
7f9467b5f33b samples
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
15 * included in all copies or substantial portions of the Software.
7f9467b5f33b samples
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
16 *
7f9467b5f33b samples
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
17 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
7f9467b5f33b samples
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
18 * EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
7f9467b5f33b samples
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
19 * MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
7f9467b5f33b samples
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
20 * NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS
7f9467b5f33b samples
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
21 * BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN
7f9467b5f33b samples
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
22 * ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN
7f9467b5f33b samples
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
23 * CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
7f9467b5f33b samples
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
24 * SOFTWARE.
7f9467b5f33b samples
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
25 **/
7f9467b5f33b samples
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
26
7f9467b5f33b samples
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
27
7f9467b5f33b samples
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
28 #include <iostream>
588
a0001c222b32 refactoring of samples
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 531
diff changeset
29 #include <orthanc/OrthancCppClient.h>
531
7f9467b5f33b samples
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
30
7f9467b5f33b samples
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
31 int main()
7f9467b5f33b samples
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
32 {
7f9467b5f33b samples
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
33 try
7f9467b5f33b samples
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
34 {
588
a0001c222b32 refactoring of samples
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 531
diff changeset
35 // The following explicit initialization is not required, except
a0001c222b32 refactoring of samples
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 531
diff changeset
36 // if you wish to specify the full path to the shared library
a0001c222b32 refactoring of samples
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 531
diff changeset
37 OrthancClient::Initialize();
531
7f9467b5f33b samples
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
38
7f9467b5f33b samples
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
39 // Display the content of the local Orthanc instance
7f9467b5f33b samples
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
40 OrthancClient::OrthancConnection orthanc("http://localhost:8042");
7f9467b5f33b samples
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
41
7f9467b5f33b samples
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
42 for (unsigned int i = 0; i < orthanc.GetPatientCount(); i++)
7f9467b5f33b samples
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
43 {
7f9467b5f33b samples
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
44 OrthancClient::Patient patient = orthanc.GetPatient(i);
7f9467b5f33b samples
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
45 std::cout << "Patient: " << patient.GetId() << std::endl;
7f9467b5f33b samples
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
46
7f9467b5f33b samples
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
47 for (unsigned int j = 0; j < patient.GetStudyCount(); j++)
7f9467b5f33b samples
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
48 {
7f9467b5f33b samples
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
49 OrthancClient::Study study = patient.GetStudy(j);
7f9467b5f33b samples
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
50 std::cout << " Study: " << study.GetId() << std::endl;
7f9467b5f33b samples
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
51
7f9467b5f33b samples
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
52 for (unsigned int k = 0; k < study.GetSeriesCount(); k++)
7f9467b5f33b samples
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
53 {
7f9467b5f33b samples
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
54 OrthancClient::Series series = study.GetSeries(k);
7f9467b5f33b samples
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
55 std::cout << " Series: " << series.GetId() << std::endl;
7f9467b5f33b samples
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
56
7f9467b5f33b samples
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
57 for (unsigned int l = 0; l < series.GetInstanceCount(); l++)
7f9467b5f33b samples
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
58 {
7f9467b5f33b samples
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
59 std::cout << " Instance: " << series.GetInstance(l).GetId() << std::endl;
7f9467b5f33b samples
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
60 }
7f9467b5f33b samples
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
61 }
7f9467b5f33b samples
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
62 }
7f9467b5f33b samples
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
63 }
7f9467b5f33b samples
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
64
588
a0001c222b32 refactoring of samples
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 531
diff changeset
65 OrthancClient::Finalize();
a0001c222b32 refactoring of samples
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 531
diff changeset
66
531
7f9467b5f33b samples
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
67 return 0;
7f9467b5f33b samples
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
68 }
7f9467b5f33b samples
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
69 catch (OrthancClient::OrthancClientException e)
7f9467b5f33b samples
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
70 {
7f9467b5f33b samples
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
71 std::cerr << "EXCEPTION: [" << e.What() << "]" << std::endl;
7f9467b5f33b samples
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
72 return -1;
7f9467b5f33b samples
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
73 }
7f9467b5f33b samples
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
74 }