1/* GLIB - Library of useful routines for C programming
2 * Copyright (C) 1995-1997 Peter Mattis, Spencer Kimball and Josh MacDonald
3 *
4 * This library is free software; you can redistribute it and/or
5 * modify it under the terms of the GNU Lesser General Public
6 * License as published by the Free Software Foundation; either
7 * version 2.1 of the License, or (at your option) any later version.
8 *
9 * This library is distributed in the hope that it will be useful,
10 * but WITHOUT ANY WARRANTY; without even the implied warranty of
11 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
12 * Lesser General Public License for more details.
13 *
14 * You should have received a copy of the GNU Lesser General Public
15 * License along with this library; if not, see <http://www.gnu.org/licenses/>.
16 */
17
18/*
19 * Modified by the GLib Team and others 1997-2000. See the AUTHORS
20 * file for a list of people on the GLib Team. See the ChangeLog
21 * files for a list of changes. These files are distributed with
22 * GLib at ftp://ftp.gtk.org/pub/gtk/.
23 */
24
25#undef G_DISABLE_ASSERT
26#undef G_LOG_DOMAIN
27
28#include <stdio.h>
29#include <string.h>
30#include "glib.h"
31
32int array[10000];
33gboolean failed = FALSE;
34
35#define TEST(m,cond) G_STMT_START { failed = !(cond); \
36if (failed) \
37 { if (!m) \
38 g_print ("\n(%s:%d) failed for: %s\n", __FILE__, __LINE__, ( # cond )); \
39 else \
40 g_print ("\n(%s:%d) failed for: %s: (%s)\n", __FILE__, __LINE__, ( # cond ), (gchar*)m); \
41 } \
42else \
43 g_print ("."); fflush (stdout); \
44} G_STMT_END
45
46#define C2P(c) ((gpointer) ((long) (c)))
47#define P2C(p) ((gchar) ((long) (p)))
48
49#define GLIB_TEST_STRING "el dorado "
50#define GLIB_TEST_STRING_5 "el do"
51
52int
53main (int argc,
54 char *argv[])
55{
56 gint i;
57 struct {
58 gchar *filename;
59 gchar *dirname;
60 } dirname_checks[] = {
61 { "/", "/" },
62 { "////", "/" },
63 { ".////", "." },
64 { ".", "." },
65 { "..", "." },
66 { "../", ".." },
67 { "..////", ".." },
68 { "", "." },
69 { "a/b", "a" },
70 { "a/b/", "a/b" },
71 { "c///", "c" },
72 { "/a/b", "/a" },
73 { "/a/b/", "/a/b" },
74#ifdef G_OS_WIN32
75 { "\\", "\\" },
76 { ".\\\\\\\\", "." },
77 { ".\\/\\/", "." },
78 { ".", "." },
79 { "..", "." },
80 { "..\\", ".." },
81 { "..\\\\\\\\", ".." },
82 { "..\\//\\", ".." },
83 { "", "." },
84 { "a\\b", "a" },
85 { "a\\b\\", "a\\b" },
86 { "\\a\\b", "\\a" },
87 { "\\a\\b\\", "\\a\\b" },
88 { "c\\\\\\", "c" },
89 { "c/\\\\", "c" },
90 { "a:", "a:." },
91 { "a:foo", "a:." },
92 { "a:foo\\bar", "a:foo" },
93 { "a:/foo", "a:/" },
94 { "a:/foo/bar", "a:/foo" },
95 { "a:/", "a:/" },
96 { "a://", "a:/" },
97 { "a:\\foo", "a:\\" },
98 { "a:\\", "a:\\" },
99 { "a:\\\\", "a:\\" },
100 { "a:\\/", "a:\\" },
101#endif
102 };
103 guint n_dirname_checks = sizeof (dirname_checks) / sizeof (dirname_checks[0]);
104
105 for (i = 0; i < n_dirname_checks; i++)
106 {
107 gchar *dirname;
108
109 dirname = g_path_get_dirname (file_name: dirname_checks[i].filename);
110 if (strcmp (s1: dirname, s2: dirname_checks[i].dirname) != 0)
111 g_error ("%s returned %s, should return %s",
112 dirname_checks[i].filename, dirname,
113 dirname_checks[i].dirname);
114 g_free (mem: dirname);
115 }
116
117 return 0;
118}
119

source code of gtk/subprojects/glib/tests/dirname-test.c