Installing AMC with MacPorts on macOS

Version 15 (Joël Brogniart, 03/23/2024 09:13 am)

1 12 Joël Brogniart
h1. Installing AMC development version on macOS
2 1
3 1
This is a translation of the French entry wiki. First translation was done by Pieter Van den Hombergh.
4 13 Joël Brogniart
5 15 Joël Brogniart
_(This installation - AMC version 1.3.0 revision commit:b94e3a20ce34 3/28/2017 - was tested with_
6 15 Joël Brogniart
* _macOS 10.12.4 (MacPorts 2.4.1, Xcode 8.3),_
7 15 Joël Brogniart
* _macOS 10.10.5 (MacPorts 2.4.1, Xcode 7.2.1)._
8 9 Joël Brogniart
9 12 Joël Brogniart
Auto Multiple Choice (AMC) is a software to manage questionnaires and multiple choice exams. It allows, from the definition of the multiple choice questions to generate sheets of questionnaires. The question types can be one only choice, multiple choices, question, right/wrong answers etc. Once the completed questionnaires are digitized, AMC automatically corrects the questionnaires. This software runs in a graphical environment X Window System on Linux and macOS. Linux is used as the develop environment, so it probably runs best there. Your mileage may vary.
10 1
11 9 Joël Brogniart
In previous versions of this note, the source code of all necessary files were shown. As these sources are provided in the associated archive and not to burden the instructions, source code no longer appear in the note.
12 10 Joël Brogniart
13 9 Joël Brogniart
It is possible to install the "1.1.2 pre-compiled version":http://project.auto-multiple-choice.net/projects/auto-multiple-choice/wiki/Installation_d'AMC_sous_OS_X , but you would miss the newest developments happening in this active project. You can also install from the source, directly from the development  repository. This will give you the bleeding edge version.
14 10 Joël Brogniart
15 12 Joël Brogniart
For the moment, this installation guide is quite technical and has only been tested on macOS 10.11.5, 10.10.5 and 10.9.5 with the corresponding latest version of Xcode. You will need "MacPorts":http://www.macports.org, a little understanding of the dependencies between different tools (Subversion, MacPorts, PERL, X11, port ...) and the macOS architecture. You should also have administrative rights on the computer. This manual is therefore unfortunately not for everyone.
16 9 Joël Brogniart
17 1
For this installation you will create a local MacPort repository. In this repository you will add macports description for AMC and possibly files for additional ports. Once these files are installed, the installation of AMC can be started.
18 1
19 1
h2. Prerequisites
20 9 Joël Brogniart
21 1
The requirements are the same as the installation of version 1.1.2 AMC. To work with the interface, AMC requires the graphical environment X Window System and X11, the Linux Libertine font, the DejaVu font family and the MacPorts installation system.
22 1
23 12 Joël Brogniart
macOS does not contain the standard X11 graphical environment. It is possible to fill this gap by installing XQuartz, an X Windows System environment running macOS. You can download the application on the XQuartz site. "XQuartz":http://xquartz.macosforge.org.
24 7 Joël Brogniart
25 1
h3. MacPorts
26 1
27 12 Joël Brogniart
MacPorts is a system to build, install and manage open source software. You need to download the macOS Yosemite installation package on the site "MacPorts":http://www.macports.org and install MacPorts.
28 1
29 1
h3. Linux Libertine font
30 9 Joël Brogniart
31 1
Linux Libertine font is a free font that covers code pages for Latin languages​​, Greek, Cyrillic languages​​, Hebrew, the International Phonetic Alphabet (and other). You need to download the package "OTF" on "LinuxLibertine.org":http://www.linuxlibertine.org site.
32 9 Joël Brogniart
33 12 Joël Brogniart
*Caution* : The current version of XQuartz (2.7.11) does not recognize the fonts installed in the user's folder. You must install the fonts by moving them in the "@/Library/Fonts@" folder.
34 9 Joël Brogniart
35 9 Joël Brogniart
h3. DejaVu font family
36 9 Joël Brogniart
37 9 Joël Brogniart
DejaVu fonts are used for japanese documentation generation.
38 9 Joël Brogniart
 Ces polices sont utilisées pour la génération des documentations en japonais. You need to download the fonts on "dejavu-fonts.org":http://dejavu-fonts.org/wiki/Download site.
39 9 Joël Brogniart
40 12 Joël Brogniart
*Caution* : The current version of XQuartz (2.7.11) does not recognize the fonts installed in the user's folder. You must install the fonts by moving them in the "@/Library/Fonts@" folder.
41 1
42 7 Joël Brogniart
h2. MacPorts installation (port) files
43 7 Joël Brogniart
44 2 Joël Brogniart
The MacPorts port file contains information that allows a program to be installed into the MacPorts system. It shows what tools are needed for installation and operation of the program and how to install the program. 
45 1
MacPorts contains "many ports":http://www.macports.org/ports.php but it does not contain a port describing the AMC installation from the source code of the program. So we have to create the file port for the development version of AMC.
46 4 Joël Brogniart
47 7 Joël Brogniart
To avoid conflicts with ports already described in MacPorts, new ports will be installed in the folders of the user who installs, instead of being installed in folders directly managed by MacPorts.
48 4 Joël Brogniart
49 7 Joël Brogniart
h3. Local MacPorts repository
50 7 Joël Brogniart
51 1
For MacPorts to use a local folder, you must create that local folder.
52 1
53 1
<pre>mkdir -p ~/nix</pre>
54 1
55 7 Joël Brogniart
You should then tell MacPorts to take the local folder into account, before considering the standard hierarchy MacPorts. To do this you must edit the file "@/opt/local/etc/macports/sources.conf@" and add a URL to the local file before the URL of the repository @rsync@ MacPorts.
56 9 Joël Brogniart
57 7 Joël Brogniart
<pre>file:///Users/julesvernes/nix/macports
58 1
rsync://rsync.macports.org/release/tarballs/ports.tar [default]</pre>
59 1
60 1
h3. Port Files
61 1
62 14 Joël Brogniart
Two archives containing the port files are available for download:
63 1
* for installation on OS X 10.9 and 10.10 attachment:macports-10.10.zip,
64 14 Joël Brogniart
* for installation on macOS 10.11 and 10.12 attachment:macports-10.12.zip.
65 12 Joël Brogniart
66 14 Joël Brogniart
First archive contains only AMC port description. Archive for macOS 10.11 and 10.12 includes an adaptation of ports @gcc5@ and @pdftk@ to make them working under these versions of macOS.
67 12 Joël Brogniart
68 4 Joël Brogniart
Download and uncompress this archive then move the "@macports@" folder inside the previously created folder.
69 4 Joël Brogniart
70 4 Joël Brogniart
!port-hierarchy.png!
71 7 Joël Brogniart
72 1
Each directory must contain a port document named @Portfile@. This document is a text document containing a description for the MacPorts installation tool.
73 1
74 9 Joël Brogniart
h4. Excerpt for @x11/auto-multiple-choice-devel/Portfile@
75 1
<pre title="x11/auto-multiple-choice-devel/Portfile"># -*- coding: utf-8; mode: tcl; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- vim:fenc=utf-8:ft=tcl:et:sw=4:ts=4:sts=4
76 4 Joël Brogniart
77 1
PortSystem              1.0
78 1
PortGroup               bitbucket 1.0
79 1
PortGroup               perl5 1.0
80 15 Joël Brogniart
PortGroup               texlive 1.0
81 9 Joël Brogniart
82 15 Joël Brogniart
set bitbucket_commit    "b94e3a20ce34"
83 15 Joël Brogniart
set amc_revision        "2030"
84 15 Joël Brogniart
#2030:b94e3a20ce34
85 4 Joël Brogniart
bitbucket.setup         auto-multiple-choice auto-multiple-choice ${bitbucket_commit}
86 9 Joël Brogniart
name                    auto-multiple-choice-devel
87 7 Joël Brogniart
version                 1.3.${amc_revision}
88 4 Joël Brogniart
categories              x11 tex education
89 1
platforms               darwin
90 1
license                 GPL-2+
91 7 Joël Brogniart
maintainers             laposte.fr:joel.brogniart,openmaintainer
92 7 Joël Brogniart
93 7 Joël Brogniart
description             Auto Multiple Choice - Multiple Choice Papers Management
94 7 Joël Brogniart
long_description        Utility to manage multiple choice questionnaires, \
95 1
                        with optionally mixed questions and answers. \
96 1
                        AMC provides automatic marking from papers' scans. \
97 9 Joël Brogniart
                        Annotated papers are produced. Marks can be exported \
98 4 Joël Brogniart
                        as an OpenOffice.org sheet file.
99 9 Joël Brogniart
100 1
homepage                http://home.gna.org/auto-qcm
101 15 Joël Brogniart
conflicts               auto-multiple-choice
102 14 Joël Brogniart
103 15 Joël Brogniart
checksums               rmd160  59c7abff5e33007289b654053dc3c9bbe05901c5 \
104 15 Joël Brogniart
                        sha256  1a5ebe1dd9030e10d41a8103e58089ef4e2ce1e212ec951327b4742260094546
105 9 Joël Brogniart
106 4 Joël Brogniart
depends_build-append    \
107 1
                        port:dblatex \
108 4 Joël Brogniart
                        port:p${perl5.major}-xml-libxml
109 7 Joël Brogniart
</pre>
110 1
111 10 Joël Brogniart
h2. Installing AMC
112 10 Joël Brogniart
113 10 Joël Brogniart
Once the port files set up, generate the index of the new port.
114 10 Joël Brogniart
<pre>cd ~/nix/macports
115 11 Joël Brogniart
portindex</pre>
116 12 Joël Brogniart
117 11 Joël Brogniart
*Warning*: standard and development of AMC versions can't be installed simultaneously. If a standard version was previously installed, you must uninstall it before installing the development version.
118 12 Joël Brogniart
119 10 Joël Brogniart
<pre>sudo port uninstall auto-multiple-choice</pre>
120 7 Joël Brogniart
121 5 Joël Brogniart
Finally install AMC.
122 7 Joël Brogniart
123 5 Joël Brogniart
<pre>sudo port install auto-multiple-choice-devel</pre>
124 5 Joël Brogniart
125 5 Joël Brogniart
The installation may take a while. When it is complete and if there is no error, AMC is ready to be used.
126 5 Joël Brogniart
127 5 Joël Brogniart
h2. Using AMC
128 7 Joël Brogniart
129 5 Joël Brogniart
You can start from the terminal or from XQuartz.
130 7 Joël Brogniart
131 5 Joël Brogniart
h3. In the Terminal
132 5 Joël Brogniart
133 5 Joël Brogniart
<pre>auto-multiple-choice</pre>
134 7 Joël Brogniart
135 5 Joël Brogniart
This command will launch XQuartz and AMC application.
136 5 Joël Brogniart
137 5 Joël Brogniart
h3. In XQuartz
138 5 Joël Brogniart
139 7 Joël Brogniart
Start XQuartz application.
140 5 Joël Brogniart
141 1
!xquartz.png!
142 5 Joël Brogniart
143 5 Joël Brogniart
We can immediately set XQuartz to facilitate the launch of AMC. Open the @Applications > Customize...@ menu.
144 7 Joël Brogniart
145 7 Joël Brogniart
!xquartz-menu-applications-personnaliser.png!
146 5 Joël Brogniart
147 5 Joël Brogniart
In the Personalization window, click the button @Add an entry@.
148 7 Joël Brogniart
149 5 Joël Brogniart
!xquartz-fenetre-personnaliser-menu-applications.png!
150 7 Joël Brogniart
151 5 Joël Brogniart
Set "@Auto Multiple Choice@" in the @Name@ column and "@auto-multiple-choice@" in the @Command@ column of the new menu item.
152 7 Joël Brogniart
153 5 Joël Brogniart
!xquartz-fenetre-personnaliser-menu-applications-2.png!
154 7 Joël Brogniart
155 5 Joël Brogniart
Close the Customize window, then select the @Applications > Auto Multiple Choice@ menu.
156 5 Joël Brogniart
157 5 Joël Brogniart
!xquartz-menu-applications-amc.png!
158 7 Joël Brogniart
159 5 Joël Brogniart
AMC window should appear.
160 7 Joël Brogniart
161 5 Joël Brogniart
!auto-multiple-choice-window.png!
162 5 Joël Brogniart
163 5 Joël Brogniart
Auto-multiple-choice is now ready to work.
164 5 Joël Brogniart
165 7 Joël Brogniart
h2. Links
166 5 Joël Brogniart
167 12 Joël Brogniart
* Auto Multiple Choice, "http://home.gna.org/auto-qcm/":http://home.gna.org/auto-qcm/.
168 5 Joël Brogniart
* Auto Multiple Choice, "Installation sous macOS (10.8)":http://project.auto-multiple-choice.net/projects/auto-multiple-choice/wiki/Installation_d'AMC_sous_OS_X_Mountain_Lion.
169 5 Joël Brogniart
* MacPorts, "http://www.macports.org":http://www.macports.org.
170 1
* MacPorts, "Local Portfile Repositories":http://guide.macports.org/#development.local-repositories.
171 1
* MacPorts, "How to create portfiles for CPAN Perl modules":https://trac.macports.org/wiki/howto/cpan2port.
172 1
* XQuartz, http://xquartz.macosforge.org</a>.