summary refs log tree commit diff stats
path: root/lib/std/private/globs.nim
blob: a6d088558273f625263c52d8447cab4b6efb2952 (plain) (blame)
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
##[
unstable API, internal use only for now.
this can eventually be moved to std/os and `walkDirRec` can be implemented in terms of this
to avoid duplication
]##

import std/os
when defined(windows):
  from std/strutils import replace

when defined(nimPreviewSlimSystem):
  import std/[assertions, objectdollar]


when defined(nimHasEffectsOf):
  {.experimental: "strictEffects".}
else:
  {.pragma: effectsOf.}

type
  PathEntry* = object
    kind*: PathComponent
    path*: string

iterator walkDirRecFilter*(dir: string, follow: proc(entry: PathEntry): bool = nil,
    relative = false, checkDir = true): PathEntry {.tags: [ReadDirEffect], effectsOf: follow.} =
  ## Improved `os.walkDirRec`.
  #[
  note: a yieldFilter isn't needed because caller can filter at call site, without
  loss of generality, unlike `follow`.

  Future work:
  * need to document
  * add a `sort` option, which can be implemented efficiently only here, not at call site.
  * provide a way to do error reporting, which is tricky because iteration cannot be resumed
  ]#
  var stack = @["."]
  var checkDir = checkDir
  var entry: PathEntry
  while stack.len > 0:
    let d = stack.pop()
    for k, p in walkDir(dir / d, relative = true, checkDir = checkDir):
      let rel = d / p
      entry.kind = k
      if relative: entry.path = rel
      else: entry.path = dir / rel
      if k in {pcDir, pcLinkToDir}:
        if follow == nil or follow(entry): stack.add rel
      yield entry
    checkDir = false
      # We only check top-level dir, otherwise if a subdir is invalid (eg. wrong
      # permissions), it'll abort iteration and there would be no way to
      # continue iteration.

proc nativeToUnixPath*(path: string): string =
  # pending https://github.com/nim-lang/Nim/pull/13265
  result = path
  when defined(windows):
    if path.len >= 2 and path[0] in {'a'..'z', 'A'..'Z'} and path[1] == ':':
      result[0] = '/'
      result[1] = path[0]
      if path.len > 2 and path[2] != '\\':
        raiseAssert "paths like `C:foo` are currently unsupported, path: " & path
  when DirSep == '\\':
    result = replace(result, '\\', '/')

when isMainModule:
  import std/sugar
  for a in walkDirRecFilter(".", follow = a=>a.path.lastPathPart notin ["nimcache", ".git", "csources_v1", "csources", "bin"]):
    echo a
ass="cm"> * certain conditions as described in each individual source file, and * distribute linked combinations including the two. * * You must obey the GNU General Public License in all respects for all of the * code used other than OpenSSL. If you modify file(s) with this exception, you * may extend this exception to your version of the file(s), but you are not * obligated to do so. If you do not wish to do so, delete this exception * statement from your version. If you delete this exception statement from all * source files in the program, then also delete it here. * */ #ifndef ACCOUNT_H #define ACCOUNT_H #include "common.h" typedef struct prof_account_t { gchar *name; gchar *jid; gchar *password; gchar *eval_password; gchar *resource; gchar *server; int port; gchar *last_presence; gchar *login_presence; gint priority_online; gint priority_chat; gint priority_away; gint priority_xa; gint priority_dnd; gchar *muc_service; gchar *muc_nick; gboolean enabled; gchar *otr_policy; GList *otr_manual; GList *otr_opportunistic; GList *otr_always; gchar *pgp_keyid; gchar *startscript; gchar *theme; gchar *tls_policy; } ProfAccount; ProfAccount* account_new(const gchar *const name, const gchar *const jid, const gchar *const passord, const gchar *eval_password, gboolean enabled, const gchar *const server, int port, const gchar *const resource, const gchar *const last_presence, const gchar *const login_presence, int priority_online, int priority_chat, int priority_away, int priority_xa, int priority_dnd, const gchar *const muc_service, const gchar *const muc_nick, const gchar *const otr_policy, GList *otr_manual, GList *otr_opportunistic, GList *otr_always, const gchar *const pgp_keyid, const char *const startscript, const char *const theme, gchar *tls_policy); char* account_create_full_jid(ProfAccount *account); gboolean account_eval_password(ProfAccount *account); void account_free(ProfAccount *account); #endif