Skip to content
Snippets Groups Projects
Select Git revision
  • 4887dfbde91051757c2e949b55357dd4d849d16c
  • master default protected
  • 9.0
  • 8.0
  • nt-tools
  • 7.8
  • 7.6
  • 7.4
  • 7.2
  • 7.0
  • 0.6
  • rosuav/latex-markdown-renderer
  • rxnpatch/rxnpatch
  • marcus/gobject-introspection
  • rxnpatch/8.0
  • rosuav/pre-listening-ports
  • rosuav/async-annotations
  • rosuav/pgsql-ssl
  • rxnpatch/rxnpatch-broken/2023-10-06T094250
  • grubba/fdlib
  • grubba/wip/sakura/8.0
  • v8.0.2020
  • v8.0.2018
  • v8.0.2016
  • v8.0.2014
  • v8.0.2012
  • v8.0.2008
  • v8.0.2006
  • v8.0.2004
  • v8.0.2002
  • v8.0.2000
  • v8.0.1998
  • v8.0.1996
  • v8.0.1994
  • v8.0.1992
  • v8.0.1990
  • v8.0.1988
  • v8.0.1986
  • rxnpatch/clusters/8.0/2025-04-29T124414
  • rxnpatch/2025-04-29T124414
  • v8.0.1984
41 results

sqlite.pike

Blame
  • user avatar
    Martin Nilsson authored
    e1fb0973
    History
    sqlite.pike 1.75 KiB
    
    #pike __REAL_VERSION__
    #require constant(SQLite.SQLite)
    
    // Cannot dump this since the #require check may depend on the
    // presence of system libs at runtime.
    constant dont_dump_program = 1;
    
    inherit SQLite.SQLite;
    
    void create(string a, void|string b, void|mixed c, void|mixed d,
    	    void|mapping options) {
      if(b) a += "/"+b;
      ::create(a);
    }
    
    array list_fields(string n, string|void wild)
    {
      string qry = "";
    
      qry = "PRAGMA table_info(" + n + ")";
    
      array r = query(qry);
    
      // now, we weed out the ones that don't match wild, if provided
      if(wild)
      {
        r = filter(r, lambda(mapping row) 
                  { return (search(row->name, wild) !=-1); }
              );
      }
    
      array fields = ({});
    
      foreach(r;; mapping f)
      {
        mapping fld = ([]);
    
        fld->name = f->name;
        fld->table = n;
      
        string t, l;   
     
        if(!sscanf(f->type, "%s(%s)", t, l))
          t = f->type;
    
        fld->length = (int)l;
    
        switch(t)
        {
          case "char":
           t = "string";
           break;
    
          case "int":
           t = "integer";
           break;
        }
    
        fld->type = t;
    
        fld->flags = (<>);
    
        if((int)f->notnull)
          fld->flags->not_null = 1;
    
        if((int)f->pk)
        {
          // primary key implies not null.
          fld->flags->not_null = 1;
          fld->flags->primary_key = 1;
        }
    
        fld->default = f->dflt_value;
    
        fields += ({fld});
      }
    
      return fields;
    }
    
    array list_tables(string|void n)
    {
      string qry = "";
    
      if(n)
        qry = "SELECT name FROM SQLITE_MASTER WHERE name like '" + n + "%' and TYPE='table'";  
      else
        qry = "SELECT name FROM SQLITE_MASTER where TYPE='table'";  
    
      array r = query(qry);
      array out = ({});
    
      foreach(r;;mapping row)
      {
        if(row->name)
          out += ({row->name});
        else
          out += ({row["sqlite_master.name"] });
      }
      return out;
    }