My Project
Loading...
Searching...
No Matches
emacs.cc File Reference
#include "kernel/mod2.h"
#include "omalloc/omalloc.h"
#include "resources/feResource.h"
#include "Singular/feOpt.h"
#include <unistd.h>
#include <stdarg.h>

Go to the source code of this file.

Macros

#define ESINGULAR
 
#define DIR_SEP   '/'
 
#define DIR_SEPP   "/"
 
#define UP_DIR   ".."
 
#define Warn   error
 
#define WarnS   error
 
#define StringAppend   printf
 
#define Print   error
 
#define feReportBug(s)
 

Functions

void error (const char *fmt,...)
 
void fePrintReportBug (char *msg, char *file, int line)
 
void mainUsage ()
 
char * feResourceDefault (const char id)
 
char * feResourceDefault (const char *key)
 
int main (int argc, char **argv)
 

Macro Definition Documentation

◆ DIR_SEP

#define DIR_SEP   '/'

Definition at line 50 of file emacs.cc.

◆ DIR_SEPP

#define DIR_SEPP   "/"

Definition at line 51 of file emacs.cc.

◆ ESINGULAR

#define ESINGULAR

Definition at line 34 of file emacs.cc.

◆ feReportBug

#define feReportBug ( s)
Value:
fePrintReportBug(s, __FILE__, __LINE__)
void fePrintReportBug(char *msg, char *file, int line)
Definition emacs.cc:83
const CanonicalForm int s
Definition facAbsFact.cc:51

Definition at line 82 of file emacs.cc.

◆ Print

#define Print   error

Definition at line 80 of file emacs.cc.

◆ StringAppend

#define StringAppend   printf

Definition at line 79 of file emacs.cc.

◆ UP_DIR

#define UP_DIR   ".."

Definition at line 52 of file emacs.cc.

◆ Warn

#define Warn   error

Definition at line 77 of file emacs.cc.

◆ WarnS

#define WarnS   error

Definition at line 78 of file emacs.cc.

Function Documentation

◆ error()

void error ( const char * fmt,
... )

Definition at line 55 of file emacs.cc.

56{
57 va_list ap;
58 va_start(ap, fmt);
59 vfprintf(stderr, fmt, ap);
60}
Definition ap.h:40

◆ fePrintReportBug()

void fePrintReportBug ( char * msg,
char * file,
int line )

Definition at line 83 of file emacs.cc.

84{
85 error("YOU HAVE FOUND A BUG IN SINGULAR.\n"
86"Please, email the following output to singular@mathematik.uni-kl.de\n"
87"Bug occurred at %s:%d\n"
88"Message: %s\n"
89"Version: " S_UNAME VERSION VERSION_DATE,
90 file, line, msg);
91
92}
#define VERSION
#define error(a)

◆ feResourceDefault() [1/2]

char * feResourceDefault ( const char * key)
extern

Definition at line 155 of file feResource.cc.

156{
158}
static feResourceConfig feGetResourceConfig(const char id)
static char * feResourceDefault(feResourceConfig config)

◆ feResourceDefault() [2/2]

char * feResourceDefault ( const char id)
extern

Definition at line 150 of file feResource.cc.

151{
153}

◆ main()

int main ( int argc,
char ** argv )

Definition at line 103 of file emacs.cc.

104{
105 char* singular = NULL;
106 char* emacs = NULL;
107#ifndef TSINGULAR
108 char* emacs_dir = NULL;
109 char* emacs_load = NULL;
110 char cwd[MAXPATHLEN];
111#endif
112 int no_emacs_call = 0;
113
114 // parse-cmdline options
115
116 feInitResources(argv[0]);
117 feResource('S');
118 feResource('b');
119 feResource('r');
120
121 int optc, option_index;
122
123 while ((optc = fe_getopt_long(argc, argv, SHORT_OPTS_STRING,
124 feOptSpec, &option_index))
125 != EOF)
126 {
127 switch(optc)
128 {
129 case 'h':
130 extern void feOptHelp(const char* name);
131
133 exit(0);
134 break;
135 case '?':
136 case ':':
137 case '\0':
138 mainUsage();
139 exit(1);
140
142 {
143 switch(option_index)
144 {
145#ifdef TSINGULAR
146 case FE_OPT_XTERM:
147 emacs = fe_optarg;
148 break;
149#else
150 case FE_OPT_EMACS:
151 emacs = fe_optarg;
152 break;
153
154 case FE_OPT_EMACS_DIR:
155 emacs_dir = fe_optarg;
156 break;
157
158 case FE_OPT_EMACS_LOAD:
159 emacs_load = fe_optarg;
160 break;
161#endif
162 case FE_OPT_SINGULAR:
163 singular = fe_optarg;
164 break;
165
166 case FE_OPT_NO_CALL:
167 no_emacs_call = 1;
168 break;
169
170 case FE_OPT_DUMP_VERSIONTUPLE:
172 exit(0);
173 break;
174
175 default:
176 goto NEXT;
177 }
178 // delete options from option-list
179 if (fe_optind > 2 && *argv[fe_optind-1] != '-' &&
180 fe_optarg != NULL && feOptSpec[option_index].has_arg)
181 {
182 argv[fe_optind-2] = NULL;
183 }
184 argv[fe_optind-1] = NULL;
185 }
186 }
187 NEXT:{}
188 }
189
190 int i, length = 0;
191 char* syscall;
192 for (i=1; i<argc; i++)
193 {
194 if (argv[i] != NULL) length += strlen(argv[i]) + 3;
195 }
196
197#ifdef TSINGULAR
198 if (emacs == NULL) emacs = feResource('X', 0);
199 if (emacs == NULL)
200 {
201 #ifdef __CYGWIN__
202 error( "Error: Can't find rxvt program. \n Expected it at %s\n Specify alternative with --rxvt=PROGRAM option,\n or set RXVT environment variable to the name of the program to use as rxvt.\n",
203 #else
204 error( "Error: Can't find xterm program. \n Expected it at %s\n Specify alternative with --xterm=PROGRAM option,\n or set XTERM environment variable to the name of the program to use as xterm.\n",
205 #endif
206 feResourceDefault('X'));
207 mainUsage();
208 exit(1);
209 }
210
211 if (singular == NULL) singular = feResource("SingularXterm", 0);
212 if (singular == NULL)
213 {
214 error( "Error: Can't find singular executable.\n Expected it at %s\n Specify with --singular option,\n or set TSINGULAR_SINGULAR environment variable.\n",
215 feResourceDefault("SingularXterm"));
216 mainUsage();
217 exit(1);
218 }
219
220#ifdef __CYGWIN__
221#define EXTRA_XTERM_ARGS "+vb -sl 2000 -fb Courier-bold-12 -tn xterm -cr Red3"
222#else
223#define EXTRA_XTERM_ARGS ""
224#endif
225
226 size_t len=strlen(emacs) + strlen(singular) + length + 300;
227 syscall = (char*) omAlloc(len);
228 snprintf(syscall,len, "%s %s -e %s ", emacs, EXTRA_XTERM_ARGS, singular);
229
230 for (i=1; i<argc; i++)
231 {
232 if (argv[i] != NULL)
233 {
234 strcat(syscall, " ");
235 strcat(syscall, argv[i]);
236 }
237 }
238#else
239 // make sure emacs, singular, emacs_dir, emacs_load are set
240 if (emacs == NULL) emacs = feResource("xemacs", 0);
241 if (emacs == NULL) emacs = feResource("emacs", 0);
242 if (emacs == NULL)
243 {
244 error( "Error: Can't find emacs or xemacs executable. \n Expected it at %s or %s\n Specify alternative with --emacs option,\n or set ESINGULAR_EMACS environment variable.\n",
245 feResourceDefault("emacs"), feResourceDefault("xemacs"));
246 mainUsage();
247 exit(1);
248 }
249
250 if (singular == NULL) singular = feResource("SingularEmacs", 0);
251 if (singular == NULL)
252 {
253 error( "Error: Can't find singular executable.\n Expected it at %s\n Specify with --singular option,\n or set ESINGULAR_SINGULAR environment variable.\n",
254 feResourceDefault("SingularEmacs"));
255 mainUsage();
256 exit(1);
257 }
258
259 if (emacs_dir == NULL) emacs_dir = feResource("EmacsDir", 0);
260 if (emacs_dir == NULL)
261 {
262 error( "Error: Can't find emacs directory for Singular lisp files. \n Expected it at %s\n Specify with --emacs-dir option,\n or set ESINGULAR_EMACS_DIR environment variable.\n",
263 feResourceDefault("EmacsDir"));
264 mainUsage();
265 exit(1);
266 }
267
268 if (emacs_load == NULL)
269 {
270 // look into env variable
271 emacs_load = getenv("ESINGULAR_EMACS_LOAD");
272 if (access(emacs_load, R_OK))
273 {
274 // look in home-dir
275 emacs_load = getenv("HOME");
276#ifdef __CYGWIN__
277 if ((emacs_load==NULL)||(!access(emacs_load,X_OK)))
278 emacs_load = getenv("SINGHOME");
279#endif
280 snprintf(cwd,MAXPATHLEN, "%s/.emacs-singular", emacs_load);
281 if (! access(cwd, R_OK))
282 {
283 emacs_load = omStrDup(cwd);
284 }
285 else
286 {
287 // try with resources
288 emacs_load = feResource("EmacsLoad", 0);
289 if (emacs_load == NULL)
290 {
291 error( "Error: Can't find emacs load file for Singular mode. \n Expected it at %s\n Specify with --emacs-load option,\n or set ESINGULAR_EMACS_LOAD environment variable,\n or put file '.emacs-singular' in your home directory.\n",
292 feResourceDefault("EmacsLoad"));
293 mainUsage();
294 exit(1);
295 }
296 }
297 }
298 }
299
300 size_t len=strlen(emacs) + strlen(singular) + strlen(emacs_dir) + strlen(emacs_load) + length +300;
301 syscall = (char*) omAlloc(len);
302 const char* prefix = "--";
303 if (strstr(emacs, "xemacs") || strstr(emacs, "Xemacs") || strstr(emacs, "XEMACS"))
304 prefix = "-";
305 getcwd(cwd, MAXPATHLEN);
306 // append / at the end of cwd
307 if (cwd[strlen(cwd)-1] != '/') strcat(cwd, "/");
308
309 // Note: option -no-init-file should be equivalent to -q. Anyhow,
310 // xemacs-20.4 sometimes crashed on startup when using -q. Donīt know why.
311 snprintf(syscall,len, "%s %sno-init-file %seval '(progn (setq singular-emacs-home-directory \"%s\") (load-file \"%s\") (singular-other \"%s\" \"%s\" (list ",
312 emacs, prefix, prefix, emacs_dir, emacs_load,
313 singular, cwd);
314
315
316 for (i=1; i<argc; i++)
317 {
318 if (argv[i] != NULL)
319 {
320 strcat(syscall, "\"");
321 strcat(syscall, argv[i]);
322 strcat(syscall, "\" ");
323 }
324 }
325 strcat(syscall, ") \"singular\"))'");
326#endif
327
328 if (no_emacs_call)
329 {
330 printf("%s\n", syscall);
331 }
332 else
333 {
334 if (system(syscall) != 0)
335 {
336 error( "Error: Execution of\n%s\n", syscall);
337 mainUsage();
338 exit(1);
339 }
340 }
341}
int i
Definition cfEzgcd.cc:132
char * feResourceDefault(const char id)
void mainUsage()
Definition emacs.cc:94
#define LONG_OPTION_RETURN
Definition feOptTab.h:4
const char SHORT_OPTS_STRING[]
Definition feOpt.cc:29
void feOptDumpVersionTuple(void)
Definition feOpt.cc:430
void feOptHelp(const char *name)
Definition feOpt.cc:379
EXTERN_VAR struct fe_option feOptSpec[]
Definition feOpt.h:17
VAR char * feArgv0
Definition feResource.cc:19
static char * feResource(feResourceConfig config, int warn)
void feInitResources(const char *argv0)
int fe_getopt_long(int argc, char *const *argv, const char *options, const struct fe_option *long_options, int *opt_index)
Definition fegetopt.c:664
char * fe_optarg
Definition fegetopt.c:94
int fe_optind
Definition fegetopt.c:109
char * getenv()
static BOOLEAN length(leftv result, leftv arg)
Definition interval.cc:257
#define omStrDup(s)
#define omAlloc(size)
#define NULL
Definition omList.c:12
#define NEXT(list)
Definition omList.c:17
#define MAXPATHLEN
Definition omRet2Info.c:22
int name
New type name for int.

◆ mainUsage()

void mainUsage ( )

Definition at line 94 of file emacs.cc.

95{
96 error( "Use `%s --help' for a complete list of options\n", feArgv0);
97}